



## DEPARTMENT OF ELECTRONICS AND COMMUNICATION ENGINEERING

## COURSE MATERIALS



## EC 207: LOGIC CIRCUIT DESIGN

## VISION OF THE INSTITUTION

To mould true citizens who are millennium leaders and catalysts of change through excellence in education.

## MISSION OF THE INSTITUTION

**NCERC** is committed to transform itself into a center of excellence in Learning and Research in Engineering and Frontier Technology and to impart quality education to mould technically competent citizens with moral integrity, social commitment and ethical values.

We intend to facilitate our students to assimilate the latest technological know-how and to imbibe discipline, culture and spiritually, and to mould them in to technological giants, dedicated research scientists and intellectual leaders of the country who can spread the beams of light and happiness among the poor and the underprivileged.

## **ABOUT DEPARTMENT**

- Established in: 2002
- Course offered : B.Tech in Electronics and Communication Engineering

M.Tech in VLSI

- Approved by AICTE New Delhi and Accredited by NAAC
- Affiliated to the A P J Abdul Kalam Technological University.

## **DEPARTMENT VISION**

Provide well versed, communicative Electronics Engineers with skills in Communication systems with corporate and social relevance towards sustainable developments through quality education.

## **DEPARTMENT MISSION**

1) Imparting Quality education by providing excellent teaching, learning environment.

2) Transforming and adopting students in this knowledgeable era, where the electronic gadgets (things) are getting obsolete in short span.

3) To initiate multi-disciplinary activities to students at earliest and apply in their respective fields of interest later.

4) Promoting leading edge Research & Development through collaboration with academia & industry.

## PROGRAMME EDUCATIONAL OBJECTIVES

PEO1. To prepare students to excel in postgraduate programmes or to succeed in industry / technical profession through global, rigorous education and prepare the students to practice and innovate recent fields in the specified program/ industry environment.

PEO2. To provide students with a solid foundation in mathematical, Scientific and engineering fundamentals required to solve engineering problems and to have strong practical knowledge required to design and test the system.

PEO3. To train students with good scientific and engineering breadth so as to comprehend, analyze, design, and create novel products and solutions for the real life problems.

PEO4. To provide student with an academic environment aware of excellence, effective communication skills, leadership, multidisciplinary approach, written ethical codes and the life-long learning needed for a successful professional career.

## PROGRAM OUTCOMES (POS)

## Engineering Graduates will be able to:

- 1. **Engineering knowledge**: Apply the knowledge of mathematics, science, engineering fundamentals, and an engineering specialization to the solution of complex engineering problems.
- 2. **Problem analysis**: Identify, formulate, review research literature, and analyze complex engineering problems reaching substantiated conclusions using first principles of mathematics, natural sciences, and engineering sciences.
- 3. **Design/development of solutions**: Design solutions for complex engineering problems and design system components or processes that meet the specified needs with appropriate consideration for the public health and safety, and the cultural, societal, and environmental considerations.
- 4. **Conduct investigations of complex problems**: Use research-based knowledge and research methods including design of experiments, analysis and interpretation of data, and synthesis of the information to provide valid conclusions.
- 5. **Modern tool usage**: Create, select, and apply appropriate techniques, resources, and modern engineering and IT tools including prediction and modeling to complex engineering activities with an understanding of the limitations.

- 6. **The engineer and society**: Apply reasoning informed by the contextual knowledge to assess societal, health, safety, legal and cultural issues and the consequent responsibilities relevant to the professional engineering practice.
- 7. **Environment and sustainability**: Understand the impact of the professional engineering solutions in societal and environmental contexts, and demonstrate the knowledge of, and need for sustainable development.
- 8. **Ethics**: Apply ethical principles and commit to professional ethics and responsibilities and norms of the engineering practice.
- 9. **Individual and team work**: Function effectively as an individual, and as a member or leader in diverse teams, and in multidisciplinary settings.
- 10. **Communication**: Communicate effectively on complex engineering activities with the engineering community and with society at large, such as, being able to comprehend and write effective reports and design documentation, make effective presentations, and give and receive clear instructions.
- 11. **Project management and finance**: Demonstrate knowledge and understanding of the engineering and management principles and apply these to one's own work, as a member and leader in a team, to manage projects and in multidisciplinary environments.
- 12. Life-long learning: Recognize the need for, and have the preparation and ability to engage in independent and life-long learning in the broadest context of technological change.

## PROGRAM SPECIFIC OUTCOMES (PSO)

**PSO1**: Facility to apply the concepts of Electronics, Communications, Signal processing, VLSI, Control systems etc., in the design and implementation of engineering systems.

**PSO2**: Facility to solve complex Electronics and communication Engineering problems, using latest hardware and software tools, either independently or in team.optimization.

#### SYLLABUS

| EC 207 | LOGIC CIRCUIT DESIGN | CATEGORY | L | Τ | P | CREDIT |
|--------|----------------------|----------|---|---|---|--------|
|        |                      | PCC      | 3 | 1 | 0 | 4      |

**Preamble:** This course aims to impart the basic knowledge of logic circuits and enable students to apply it to design a digital system.

Prerequisite: Basics of Electrical and Electronics Engineering

Course Outcomes: After the completion of the course the student will be able to

| CO 1 | Explain the elements of digital system abstractions such as digital representations of information, digital logic and Boolean algebra |
|------|---------------------------------------------------------------------------------------------------------------------------------------|
| CO 2 | Create an implementation of a combinational logic function described by a truth table using and/or/inv gates/ muxes                   |
| CO 3 | Compare different types of logic families with respect to performance and efficiency                                                  |
| CO 4 | Design a sequential logic circuit using the basic building blocks like flip-flops                                                     |
| CO 5 | Design and analyze combinational and sequential logic circuits through gate level Verilog models.                                     |

## Mapping of course outcomes with program outcomes

|      | РО<br>1 | PO 2 | PO 3 | PO 4 | PO 5 | PO 6 | PO 7 | PO 8 | PO 9 | PO<br>10 | PO<br>11 | PO 12 |
|------|---------|------|------|------|------|------|------|------|------|----------|----------|-------|
| CO 1 | 3       | 3    |      |      |      |      |      |      |      |          |          |       |
| CO 2 | 3       | 3    | 3    |      |      |      |      |      |      |          |          |       |
| CO 3 | 3       | 3    |      |      |      |      |      |      |      |          |          |       |
| CO 4 | 3       | 3    | 3    |      |      |      |      |      |      |          |          |       |
| CO 5 | 3       | 3    | 3    |      | 3    |      |      |      |      |          |          |       |

#### **Assessment Pattern**

| Bloom's Category | Continuous Ass | essment Tests | End Semester Examination |
|------------------|----------------|---------------|--------------------------|
|                  | 1              | 2             |                          |
| Remember         | 10             | 10            | 10                       |
| Understand       | 20             | 20            | 20                       |
| Apply            | 20             | 20            | 70                       |
| Analyse          |                |               |                          |
| Evaluate         |                |               |                          |
| Create           |                |               |                          |

#### Mark distribution

| Total Marks | CIE | ESE | ESE Duration |
|-------------|-----|-----|--------------|
| 150         | 50  | 100 | 3 hours      |

#### **Continuous Internal Evaluation Pattern:**

| Attendance                             | : 10 marks |
|----------------------------------------|------------|
| Continuous Assessment Test (2 numbers) | : 25 marks |
| Course project                         | : 15 marks |

## Course Level Assessment Questions Course Outcome 1 (CO1) : Number Systems and Codes

- 1. Consider the signed binary numbers A = 01000110 and B = 11010011 where B is in 2's complement form. Find the value of the following mathematical expression (i) A + B (ii) A B
- 2. Perform the following operations (i)D9CE<sub>16</sub>-CFDA<sub>16</sub> (ii) 6575<sub>8</sub>-5732<sub>8</sub>
- 3. Convert decimal 6,514 to both BCD and ASCII codes. For ASCII, an even parity bit is to be appended at the left.

## Course Outcome 2 (CO2) : Boolean Postulates and combinational circuits

- 1. Design a magnitude comparator to compare two 2-bit numbers  $A = A_1A_0$  and  $B = B_1B_0B$
- 2. Simplify using K-map  $F(a,b,c,d) = \Sigma m (4,5,7,8,9,11,12,13,15)$
- 3. Explain the operation of a 8x1 multiplexer and implement the following using an 8x1 multiplexer F(A, B, C, D) =  $\Sigma$  m (0, 1, 3, 5, 6, 7, 8, 9, 11, 13, 14)

## Course Outcome 3 (CO3) : Logic families and its characteristics

- 1. Define the terms noise margin, propagation delay and power dissipation of logic families. Compare TTL and CMOS logic families showing the values of above mentioned terms.
- 2. Draw the circuit and explain the operation of a TTL NAND gate
- 3. Compare TTL, CMOS logic families in terms of fan-in, fan-out and supply voltage

### **Course Outcome 4 (CO4) : Sequential Logic Circuits**

- 1. Realize a T flip-flop using NAND gates and explain the operation with truth table, excitation table and characteristic equation
- 2. Explain a MOD 6 asynchronous counter using JK Flip Flop
- 3. Draw the logic diagram of 3 bit PIPO shift register with LOAD/SHIFT control and explain its working

#### Course Outcome 5 (CO5) : Logic Circuit Design using HDL

- 1. Design a 4-to-1 mux using gate level Verilog model.
- 2. Design a verilog model for a half adder circuit. Make a one bit full adder by connecting two half adder models.
- 3. Compare concurrent signal assignment versus sequential signal assignment.

#### **Syllabus**

#### Module 1: Number Systems and Codes:

Binary and hexadecimal number systems; Methods of base conversions; Binary and hexadecimal arithmetic; Representation of signed numbers; Fixed and floating point numbers; Binary coded decimal codes; Gray codes; Excess 3 code. Alphanumeric codes: ASCII. Basics of verilog -- basic language elements: identifiers, data objects, scalar data types, operators.

#### **Module 2: Boolean Postulates and Fundamental Gates**

Boolean postulates and laws – Logic Functions and Gates De-Morgan's Theorems, Principle of Duality, Minimization of Boolean expressions, Sum of Products (SOP), Product of Sums (POS), Canonical forms, Karnaugh map Minimization. Modeling in verilog, Implementation of gates with simple verilog codes.

#### **Module 3: Combinatorial and Arithmetic Circuits**

Combinatorial Logic Systems - Comparators, Multiplexers, Demultiplexers, Encoder, Decoder. Half and Full Adders, Subtractors, Serial and Parallel Adders, BCD Adder. Modeling and simulation of combinatorial circuits with verilog codes at the gate level.

#### Module 4: Sequential Logic Circuits:

Building blocks like S-R, JK and Master-Slave JK FF, Edge triggered FF, Conversion of Flipflops, Excitation table and characteristic equation. Implementation with verilog codes. Ripple and Synchronous counters and implementation in verilog, Shift registers-SIPO, SISO, PISO, PIPO. Shift Registers with parallel Load/Shift, Ring counter and Johnsons counter. Asynchronous and Synchronous counter design, Mod N counter. Modeling and simulation of flipflops and counters in verilog.

#### Module 5: Logic families and its characteristics:

TTL, ECL, CMOS - Electrical characteristics of logic gates – logic levels and noise margins, fan-out, propagation delay, transition time, power consumption and power-delay product. TTL inverter - circuit description and operation; CMOS inverter - circuit description and operation; Structure and operations of TTL and CMOS gates; NAND in TTL and CMOS, NAND and NOR in CMOS.

#### **Text Books**

- 1. Mano M.M., Ciletti M.D., "Digital Design", Pearson India, 4th Edition. 2006
- 2. D.V. Hall, "Digital Circuits and Systems", Tata McGraw Hill, 1989
- 3. S. Brown, Z. Vranesic, "Fundamentals of Digital Logic with Verilog Design", McGraw Hill
- 4. Samir Palnikar"Verilog HDL: A Guide to Digital Design and Syntheis", Sunsoft Press
- 5. R.P. Jain, "Modern digital Electronics", Tata McGraw Hill, 4th edition, 2009

#### **Reference Books**

- 1. W.H. Gothmann, "Digital Electronics An introduction to theory and practice", PHI, 2<sup>nd</sup> edition ,2006
- 2. Wakerly J.F., "Digital Design: Principles and Practices," Pearson India, 4th 2008
- 3. A. Ananthakumar ,"Fundamentals of Digital Circuits", Prentice Hall, 2nd edition, 2016
- 4. Fletcher, William I., An Engineering Approach to Digital Design, 1st Edition, Prentice Hall India, 1980

#### **Course Contents and Lecture Schedule**

| No  | Торіс                                                                   | No. of L | ectures |
|-----|-------------------------------------------------------------------------|----------|---------|
| 1   | Number Systems and Codes:                                               |          |         |
| 1.1 | Binary, octal and hexadecimal number systems; Methods of base           |          | 2       |
|     | conversions;                                                            |          |         |
| 1.2 | Binary, octal and hexadecimal arithmetic;                               |          | 1       |
| 1.3 | Representation of signed numbers; Fixed and floating point numbers      | \$;      | 3       |
| 1.4 | Binary coded decimal codes; Gray codes; Excess 3 code :                 |          | 1       |
| 1.5 | Error detection and correction codes - parity check codes and H         | amming   | 3       |
|     | code-Alphanumeric codes:ASCII                                           |          |         |
| 1.6 | Verilog basic language elements: identifiers, data objects, scalar data | a types, | 2       |
|     | operators                                                               |          |         |
|     |                                                                         |          |         |
|     |                                                                         |          |         |
| 2   | <b>Boolean Postulates and Fundamental Gates:</b>                        |          |         |
| 2.1 | Boolean postulates and laws - Logic Functions and Gates, De-Morg        | an's     | 2       |
|     | Theorems, Principle of Duality                                          |          |         |
| 2.2 | Minimization of Boolean expressions, Sum of Products (SOP), Prod        | uct of   | 2       |
|     | Sums (POS)                                                              |          |         |

| 2.3 | Canonical forms, Karnaugh map Minimization                                     | 1 |
|-----|--------------------------------------------------------------------------------|---|
| 2.4 | Gate level modelling in Verilog: Basic gates, XOR using NAND and NOR           | 2 |
|     |                                                                                |   |
| 3   | Combinatorial and Arithmetic Circuits                                          |   |
|     |                                                                                |   |
| 3.1 | Combinatorial Logic Systems - Comparators, Multiplexers, Demultiplexers        | 2 |
| 3.2 | Encoder, Decoder, Half and Full Adders, Subtractors, Serial and Parallel       | 3 |
|     | Adders, BCD Adder                                                              |   |
|     |                                                                                |   |
| 3.3 | Gate level modelling combinational logic circuits in Verilog: half adder, full | 3 |
|     | adder, mux, demux, decoder, encoder                                            |   |
|     |                                                                                |   |
| 4   | Sequential Logic Circuits:                                                     |   |
| 4.1 | Building blocks like S-R, JK and Master-Slave JK FF, Edge triggered FF         | 2 |
| 4.2 | Conversion of Flipflops, Excitation table and characteristic equation.         | 1 |
| 4.3 | Ripple and Synchronous counters, Shift registers-SIPO.SISO,PISO,PIPO           | 2 |
| 4.4 | Ring counter and Johnsons counter, Asynchronous and Synchronous                | 3 |
|     | counter design                                                                 |   |
| 4.5 | Mod N counter, Random Sequence generator                                       | 1 |
| 4.6 | Modelling sequential logic circuits in Verilog: flipflops, counters            | 2 |
|     |                                                                                |   |
| 5   | Logic families and its characteristics:                                        |   |
| 5.1 | TTL.ECL.CMOS- Electrical characteristics of logic gates – logic levels and     | 3 |
|     | noise margins, fan-out, propagation delay, transition time, power              | 6 |
|     | consumption and power-delay product.                                           |   |
| 5.2 | TTL inverter - circuit description and operation                               | 1 |
| 5.3 | CMOS inverter - circuit description and operation                              | 1 |
| 5.4 | Structure and operations of TTL and CMOS gates; NAND in TTL, NAND              | 2 |
|     | and NOR in CMOS.                                                               |   |
|     |                                                                                |   |



## **QUESTION BANK**

## Module-1

1. Perform inter-conversions of the following:

(a) AC0BFE16 to Binary, Octal and Decimal

(b) 775048 to Binary, Hexadecimal and Decimal

(c) 111012 to Octal, Hexadecimal and Decimal

(d) 7750410 to Binary, Hexadecimal and Octal

(e) 7750410 to BCD 8421 and 2421

(f) 13710 to IEEE 754 Floating point number

2. Perform the subtraction of 6510 from 11010 using 2's complement arithmetic on 8-bit signed numbers and validate your answer.

3. Verify the following Verilog relational statement:

Given A, B, C, and D are operands, show with steps,

Given that A=110, B=111, C=011000, D=111011

4. Show the floating-point representation of the decimal number 228, in version-1, version-2 and IEEE 754 notation.

5. Represent decimal number 228 using excess-3 code.

6. Explain with the aid of examples the 8421, 2421, Excess-3 and Gray Code. State which are weighted codes and unweighted codes.

7. Add the numbers FADE.BEE16 and BAD.FAB16 using hexadecimal arithmetic.

8. Explain the Data types in Verilog with examples.

9. Show the floating-point representation of the decimal number 232, in version-1, version-2 and IEEE 754 notation.

10. Add the numbers DEAD.BEEF16 and 100011.1010012 using hex arithmetic.

11. Add the numbers 677.4328 and 333.1238 using octal arithmetic with the aid of octal number line.

12. Explain the operation of each of the Verilog statements given below:

reg [7:0] b= 8'hA3;
{Carry, Sum} = a+ b;
integer signed a= 16'hBEEF;

ECE DEPARTMENT, NCERC PAMPADY

13. Show the floating-point representation of the decimal number 238, in version-1, version-2 and IEEE 754 notation.

14. State what is Gray code? Draw the 4-bit Gray code representation. Provide the applications.

15. Explain about use of Parity bits for error detection.

16. Perform the following additions using bcd arithmetic and validate your answer: Add 12345 and 7234.

## Module-2

- State De Morgan's Theorem and the rules. Apply the theorem as many times as needed to obtain the complement of the following function in standard canonical form:
   f' = (x'.y. z' + x'.y'.z)'
- 2. Explain the Principle of Duality with the aid of examples.
- **3.** State and prove the Involution Theorem and the Absorption Theorem.
- 4. State and prove the Associative Theorem and the Idempotent Theorem.
- 5. What is a Truth Table? With the aid of Truth Table prove the De Morgan's Theorem.
- **6.** Examine the different sets of Logic Gates with the aid of symbol, function and truth table.
- 7. Compare and contrast Buffer gate and Invertor gate.
- **8.** Decompose the Exclusive OR Function using universal gates with the aid of truth table, logic diagram and modified logic diagram. Write Verilog program for the result.
- **9.** Simplify the following Boolean expression using appropriate Karnaugh Map and provide the logic implementation of the minimized expression using gates.

$$f(A, B, C, D) = \sum m(4, 5, 7, 8, 9, 11, 12, 13, 15)$$

- **10.** Construct the Verilog program module for the implementation in Q.9 and carefully provide comments for each line of the code.
- **11.** Explain the standard canonical forms for representing Boolean functions with the aid of two examples each.
- **12.** Explain the meaning of Literal, Minterm, Maxterm, Don't Care term, SOP and POS. Give examples to support your answers.
- **13.** Simplify the following Boolean expression using appropriate Karnaugh Map and provide the logic implementation of the minimized expression using <u>universal gates</u> with the aid of De Morgan's laws.

ECE DEPARTMENT, NCERC PAMPADY

 $f=\sum m(0,2,3,4,5,6)$ 

- **14.** Construct the Verilog program module for the above implementation in Q.13 and carefully provide comments for each line of the code.
- **15.** Decompose the Exclusive NOR Function using universal gates with the aid of truth table, logic diagram and modified logic diagram. Write Verilog program for the result.
- 16. State De Morgan's Theorem and the rules. Apply the theorem as many times as needed to obtain the complement of the following function in standard canonical form:  $f_2' = [(x.(y'. z' + y.z))]'$
- **17.** Simplify the following Boolean expression using appropriate Karnaugh Map and provide the logic implementation of the minimized expression using <u>universal gates</u> with the aid of De Morgan's laws.

π M (0,3,5,6,7).

- **18.** Construct the Verilog program module for the above implementation in Q.17 and carefully provide comments for each line of the code.
- **19.** Write a well commented Verilog program for a circuit that has four input signals, x<sub>1</sub>, x<sub>2</sub>, x<sub>3</sub>, and x<sub>4</sub>, and three output signals, f, g, and h, and implements the logic functions:

 $g = x_1.x_3 + x_2.x_4$ h = (x\_1 + x\_3')(x\_2' + x\_4) f = g + h

**20.** Obtain the complement of the following function in standard canonical form by applying the De Morgan's rule as many times as needed, as well as Principle of Duality:

 $f_1 = (x + y + z)(x + y' + z)(x' + y + z')(x' + y' + z)$ 

- **21.** Construct an XOR gate using NAND gates and perform gate level modeling using Verilog.
- 22. Construct an XOR gate using NOR gates and perform gate level modeling using Verilog.
- **23.** Repeat the above for XNOR Gate.

## Module-3 (Part-1)

- 1. State what is meant by a Combinational circuit? Draw a generic block diagram. Give four examples.
- 2. Analyze the Comparator circuits with the aid of graphic symbol and logic implementations.
- **3.** Define the Multiplexer function. Analyze the 4:1 MUX with the aid of graphic symbol, truth table and logic implementation.
- **4.** Implement the following Boolean function using an appropriate Multiplexer after judicious manipulation of the original truth table.

 $f = w1 \bigoplus w2 \bigoplus w3$ 

- **5.** Give a practical application of Multiplexer circuits in Digital Electronics and Communications or Entertainment. Try to specify a MUX of specific size and provide the blueprint for your design.
- **6.** State what is meant by a Decoder? Analyze the 2:4 Decoder with the aid of graphic symbol, truth table and logic circuit.
- 7. Analyze how the basic Decoder can be made more efficient by means of the Enable input. Draw the graphic symbol, truth table and logic circuit.
- 8. Define the Demultiplexer function. Analyze the 1:8 DEMUX with the aid of graphic symbol, truth table and logic implementation. Give an application of this function.
- **9.** Implement the following Boolean function using an appropriate Multiplexer after judicious manipulation of the original truth table.

 $f = x \otimes y \otimes z$ ,

where  $(S) \rightarrow Ex$ -NOR function

- **10.** State what is meant by a Magnitude Comparator? Analyze the 4-bit Magnitude Comparator with the aid of graphic symbol, truth table and logic circuit.
- **11.** Analyze the 3:8 Decoder by means of the graphic symbol, truth table and logic circuit. How would an extra enable input improve its robustness?
- **12.** State what is meant by Encoder? Analyze the 4:2 Encoder by means of the graphic symbol, truth table and logic circuit.
- **13.** Investigate the Priority Encoder circuit as an improvement over plain ol' Encoder with the aid of an example.
- **14.** Analyze the Full Adder and Half Adder with the aid of truth table and logic circuit diagram.

## Module-3 (Part-2)

- **1.** Describe the BCD Adder with the help of Logic Diagram and Functional table of operation.
- 2. Analyze the Ripple Carry Adder with the help of Logic Diagram and Functional table of operation.

- **3.** Describe the Binary Subtractor with overflow detection with the help of Logic Diagram and operation. Also explain the detection of Overflow.
- **4.** Describe the Priority Encoder with the help of Logic Diagram and Functional table of operation
- **5.** Analyze the 4-bit Magnitude Comparator with the help of logic expressions, Logic Diagram and operational description.
- 6. Analyze the 16:1 Multiplexer using the 4:1 Multiplexer with logic diagram and develop the Hierarchical Verilog Code for the 16:1 Multiplexer using functional description of 4:1 Multiplexer code. Describe the steps in arriving at the final code.
- **7.** State what is meant by a Decoder? Analyze the 2:4 Decoder with the aid of graphic symbol, truth table and logic circuit.
- 8. Analyze how the basic Decoder can be made more efficient by means of the Enable input. Draw the graphic symbol, truth table and logic circuit.
- 9. Analyze the 2:4 Decoder with the aid of truth table and logic diagram and develop the Verilog Code using case statement for the 2:4 Decoder system. Describe the steps in arriving at the final code.
- **10.** Use Verilog code to model a Full Adder system using Gate primitives, by starting with the logic diagram of a Full Adder.
- **11.** Use Verilog code to model a 4-bit Binary Adder system using Gate primitives, by starting with the functional description of a Full Adder.
- **12.** Use Verilog code to model a 4:1 MUX using Gate primitives, by starting with the logic diagram of a Full Adder.
- **13.** Use Verilog code to model a 16:1 MUX using Hierarchical coding, by starting with the functional description of a 4:1 MUX.
- 14. Use Verilog code to model a 2:4 Decoder using Gate primitives, by starting with the logic diagram.
- **15.** Use Verilog code to model a 2:4 Decoder in an alternative way using case statement along with Gate primitives, by starting with the logic diagram.

## Module-4

- 1. What is a Sequential system? With the aid of a block diagram, explain how a sequential circuit can be constructed.
- 2. Analyze the S R Latch with the aid of Logic diagram and Functional table. How does the addition of an enable input make the latch operate with clock signal. What is the main drawback of this latch?
- **3.** Analyze the Transparent Latch with the aid of Logic diagram and Functional table. Represent the Graphic symbols for this latch.
- **4.** Analyze the ET Flip Flop or MSD Flip Flop with the aid of Logic diagram and Functional table. Represent the Graphic symbols for this flip flop.
- **5.** Compare and Contrast Latch and Flip Flop. With diagrams, dissect the structure of a periodic clock signal that caters for each of these.
- **6.** Describe the J-K Flip Flop with the aid of Logic Diagram and Functional table or Characteristic Table. Why is this called Universal Flip Flop?
- 7. Describe the realization of T Flip Flop and D Flip Flop from the Universal Flip Flop, with clear reference to additional hardware requirements.
- 8. Draw the Characteristic Tables, write down the characteristic equations and draw the Excitation Tables for the S-R, D, J-K and T flip flops.
- **9.** Analyze the Binary Ripple Counter using D Flip Flops/ T Flip Flops and describe the operation with the aid of Count table.
- **10.** Configure a 4-bit Synchronous Counter using J-K Flip Flops and provide the functional table, logic diagram, Count table and describe its operation. Compare with Ripple Counter of same capacity.
- **11.** Configure a 4-bit Parallel Access Shift Register using D Flip- Flops and provide the functional table, logic diagram and describe its operation for the various modes such as SISO, SIPO, PISO and PIPO.
- **12.** Describe the Ring Counter and the Johnson Counter with the aid of Logic Diagram, Functional table and details of operation.
- **13.** Construct the hierarchical Verilog code for a 4-bit Shift Register with the help of functional code of D Flip Flop. Comment on the suitability of the code.
- 14. Construct the Verilog code for an Up Counter. Comment on the suitability of the code.

ECE DEPARTMENT, NCERC PAMPADY

**15.** Analyze the Verilog construct of use in Sequential circuits and construct the code for a D Flip Flop operating on the rising edge of the clock, with use of Asynchronous reset input. Comment on the sensitivity list.

## Module-5

- **1.** Analyze the CMOS Logic Levels for Input voltage and Output voltages with the aid of diagrams.
- **2.** Analyze the TTL Logic Levels for Input voltage and Output voltages with the aid of diagrams.
- 3. Justify the need for Noise Immunity in Digital Logic Systems.
- **4.** Define Noise Margin. Explain the quantitative measures for Noise Margin with the aid of diagrams of CMOS 5 V family.
- **5.** Determine the High-level and LOW-level noise margins for CMOS and for TTL using their logic level voltage ranges. Which is preferable for a noise prone environment?
- **6.** Analyze the Power Dissipation in logic circuits and obtain quantitative measures of the same.
- 7. A certain gate draws 3  $\mu$ A when its output is HIGH and 4.6  $\mu$ A when its output is LOW. What is its average power dissipation if V<sub>cc</sub> is 5 V and the gate is operated on a 50% duty cycle?
- 8. A certain IC gate has an  $I_{CCH} = 1.5\mu A$  and  $I_{CCL} = 2.8 \mu A$ . Determine the average Power dissipation for 50% duty cycle operation if  $V_{cc}$  is 5 V.
- **9.** Analyze the Binary Ripple Counter using D Flip Flops/ T Flip Flops and describe the operation with the aid of Count table.
- 10. Compare and contrast the Power Dissipation in CMOS and TTL circuits.
- **11.** Analyze the Propagation time Delay in Logic circuits and justify how the Speed- Power product can be used as a benchmark.
- **12.** Explain the Loading and Fan-out of the Gates. How does excessive loading affect the Noise Margin of the gates?
- 13. Describe the CMOS Loading with the help of diagrams.
- 14. Describe the TTL Loading with the help of diagrams.
- **15.** Analyze the CMOS Inverter circuit with the aid of Circuit Diagram and Operational Diagrams.

ECE DEPARTMENT, NCERC PAMPADY

- **16.** Analyze the TTL Inverter circuit with the aid of Circuit Diagram and Operational Diagrams.
- **17.** Analyze the TTL NAND Gate circuit with the aid of Circuit Diagram and Operational Diagrams.
- **18.** Analyze the CMOS NAND gate circuit with the aid of Circuit Diagram and functional table and operation.
- **19.** Analyze the CMOS NOR gate circuit with the aid of Circuit Diagram and functional table and operation.
- **20.** Explain the ECL Family of digital logic circuits.
- **21.** Analyze the ECL NOR/OR gate with the aid of circuit diagram, operation and transfer characteristic.
- 22. Explain the Noise margin of ECL circuits.
- 23. Compare and contrast the ECL, CMOS and TTL family of logic gates.

## ECT 203 LOGIC CIRCUIT DESIGN

This course aims to impart the basic knowledge of Logic Circuits and enable students to apply it to design a Digital System.

## Module - I: Number Systems and Codes:

## Introduction

A digital computer stores data in terms of digits (numbers) and proceeds in discrete steps from one state to the next. The states of a digital computer typically involve binary digits which may take the form of the presence or absence of magnetic markers in a storage medium, on-off switches or relays. In digital computers, even letters, words and whole texts are represented digitally.

Digital Logic is the basis of electronic systems, such as computers and cell phones. Digital Logic is rooted in binary code, a series of zeroes and ones each having an opposite value. This system facilitates the design of electronic circuits that convey information, including logic gates. Digital Logic gate functions include and, or and not. The value system translates input signals into specific output. Digital Logic facilitates computing, robotics and other electronic applications.

Digital Logic Design is foundational to the fields of electrical engineering and computer engineering. Digital Logic designers build complex electronic components that use both electrical and computational characteristics. These characteristics may involve power, current, logical function, protocol and user input. Digital Logic Design is used to develop hardware, such as circuit boards and microchip processors. This hardware processes user input, system protocol and other data in computers, navigational systems, cell phones or other high-tech systems.

### **1.2 NUMBER SYSTEMS**

### **Decimal Numbers**

A decimal number such as 7,392 represents a quantity equal to 7 thousands, plus 3 hundreds, plus 9 tens, plus 2 units. The thousands, hundreds, etc., are powers of 10 implied by the position of the coefficients (symbols) in the number. To be more exact, 7,392 is a shorthand notation for what should be written as:

 $7 {\times} 10^3 + 3 {\times} 10^2 + 9 {\times} 10^1 + 2 {\times} 10^0$ 

However, the convention is to write only the numeric coefficients and, from their position, deduce the necessary powers of 10, with powers increasing from right to left. In general, a number with a decimal point is represented by a series of coefficients:

a5a4a3a2a1a0. a-1a-2a-3

The coefficients aj are any of the 10 digits (0, 1, 2, ..., 9), and the subscript value *j* gives the place value and, hence, the power of 10 by which the coefficient must be multiplied.

So 7392 can be expanded with a3=7, a2=3, a1=9, and a0=2, and the other coefficients equal to zero.

The radix of a number system determines the number of distinct values that can be used to represent any arbitrary number. The decimal number system is said to be of base, or radix, 10 because it uses 10 digits and the coefficients are multiplied by powers of 10.

The radix point (e.g., the decimal point) distinguishes positive powers of 10 from negative powers of 10.

## **Binary Numbers**

The binary system is a different number system. The coefficients of the binary number system have only two possible values: 0 and 1. So the radix is 2. Each coefficient aj is multiplied by a power of the radix, for example,  $2^{j}$ , and the results are added to obtain the decimal equivalent of the number. The radix point or the binary point distinguishes positive powers of 2 from negative powers of 2.

For example, consider the binary number  $11010.11_2$ 

Find the decimal equivalent of the binary number  $11010.11_2$ 

11010.11<sub>2</sub> can be expanded as  $1 \times 2^4 + 1 \times 2^3 + 0 \times 2^2 + 1 \times 2^1 + 0 \times 2^0 + 1 \times 2^{-1} + 1 \times 2^{-2} = 26.75_{10}$ 

So  $26.75_{10}$  is the decimal equivalent of  $11010.11_2$ 

Given a decimal number, the binary equivalent can be found by repeatedly dividing by 2 and extracting the remainder of the series of divisions, till the quotient becomes 1 and then arrange the remainders from bottom to top.

For example, find the binary equivalent of  $24_{10}$ 

 $2|24 \rightarrow 0$   $2|12 \rightarrow 0$   $2|6 \rightarrow 0 \rightarrow 11000$   $2|3 \rightarrow 1$   $1 \rightarrow 0$ 

Therefore,  $24_{10} \equiv 11000_2$ 

## **Octal Numbers**

The octal system is a different number system. The coefficients of the octal number system have only eight possible values: 0, 1, 2, 3, 4, 5, 6 and 7. So the radix is 8. Each coefficient aj is multiplied by a power of the radix, for example, 8<sup> j</sup>, and the results are added to obtain the

decimal equivalent of the number. The radix point or the octal point distinguishes positive powers of 8 from negative powers of 8.

For example, consider the octal number  $1004.02_8$ 

Find the decimal equivalent of the octal number 1004.028

1004.02<sub>8</sub> can be expanded as  $1 \times 8^3 + 0 \times 8^2 + 0 \times 8^1 + 4 \times 8^0 + 0 \times 8^{-1} + 2 \times 8^{-2} = 516.03125_{10}$ 

So  $516.03125_{10}$  is the decimal equivalent of  $1004.02_8$ 

The conversion between octal numbers and binary numbers is much simpler and faster to perform. Simply represent each octal digit as a combination of 3 binary digits or bits. Similarly to convert binary numbers to octal, group sets of 3 bits from the lsb to the msb. If you run out of bits add zeros from the msb.

| Octal | Bits |
|-------|------|
| Digit |      |
| 0     | 000  |
| 1     | 001  |
| 2     | 010  |
| 3     | 011  |
| 4     | 100  |
| 5     | 101  |
| 6     | 110  |
| 7     | 111  |

Example: Convert the octal number 7765431<sub>8</sub> to binary

lsb

Example: Convert the binary number 1100011<sub>2</sub> to octal

$$\stackrel{= 001}{\leftarrow} \stackrel{100 \ 011}{\leftarrow} \\ 1 \ 4 \ 3 \quad \rightarrow 143_8$$

## **Hexadecimal Numbers**

The hexadecimal system is a different number system. The coefficients of the hex number system have 16 possible values: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E and F. So the radix is 16. Each coefficient aj is multiplied by a power of the radix, for example, 16<sup> j</sup>, and the results are added to obtain the decimal equivalent of the number. The radix point or the hex point distinguishes positive powers of 16 from negative powers of 16.

msb

For example, consider the hex number 100A<sub>16</sub>

Find the decimal equivalent of the hex number  $100A_{16}$ 

 $100A_{16}$  can be expanded as  $1 \times 16^3 + 0 \times 16^2 + 0 \times 16^1 + 10 \times 16^0 = 4106_{10}$ 

So  $4106_{10}$  is the decimal equivalent of  $100A_{16}$ 

The conversion between hex numbers and binary numbers is much simpler and faster to perform. Simply represent each hex digit as a combination of 4 binary digits or bits. Similarly to convert binary numbers to hex, group sets of 4 bits from the lsb to the msb. If you run out of bits add zeros from the msb.

| Hexadecimal | Bits |
|-------------|------|
| Digit       |      |
| 0           | 0000 |
| 1           | 0001 |
| 2           | 0010 |
| 3           | 0011 |
| 4           | 0100 |
| 5           | 0101 |
| 6           | 0110 |
| 7           | 0111 |
| 8           | 1000 |
| 9           | 1001 |
| А           | 1010 |
| В           | 1011 |
| С           | 1100 |
| D           | 1101 |
| Е           | 1110 |
| F           | 1111 |

Example: Convert the HEX number ABCDE<sub>16</sub> to binary

msb lsb

 $ABCDE_{16} = 1010\ 1011\ 1100\ 1101\ 1110 \equiv$ 

101010111100110111102

Example: Convert the binary number  $1100011_2$  to hex

$$= \underbrace{0000\ 0110\ 0011}_{0\ 6\ 3} \rightarrow 063_{16}$$

LOGIC CIRCUIT DESIGN

More examples:

 $100011001110_2 = 100\ 011\ 001\ 110_2 = 4316_8$ 1110110110101001\_2 = 011\ 101\ 101\ 110\ 1001\_2 = 355651\_8

The procedure for binary to hexadecimal conversion is similar, except we use groups of four bits:

 $100011001110_2 = 100011001110_2 = 8CE_{16}$ 111011011001001\_2 = 00011101101110101001\_2 = 1DBA9\_{16}

In these examples we have freely added zeroes on the left to make the total number of bits a multiple of 3 or 4 as required.

| Table 1<br>Binary, decimal, | Binary | Decimal | Octal | 3-Bit<br>String | Hexadecimal | 4-Bit<br>String |
|-----------------------------|--------|---------|-------|-----------------|-------------|-----------------|
| hexadecimal                 | 0      | 0       | 0     | 000             | 0           | 0000            |
| numbers.                    | 1      | 1       | 1     | 001             | 1           | 0001            |
|                             | 10     | 2       | 2     | 010             | 2           | 0010            |
|                             | 11     | 3       | 3     | 011             | 3           | 0011            |
|                             | 100    | 4       | 4     | 100             | 4           | 0100            |
|                             | 101    | 5       | 5     | 101             | 5           | 0101            |
|                             | 110    | 6       | 6     | 110             | 6           | 0110            |
|                             | 111    | 7       | 7     | 111             | 7           | 0111            |
|                             | 1000   | 8       | 10    | <del></del>     | 8           | 1000            |
|                             | 1001   | 9       | 11    | _               | 9           | 1001            |
|                             | 1010   | 10      | 12    | _               | Α           | 1010            |
|                             | 1011   | 11      | 13    | —               | в           | 1011            |
|                             | 1100   | 12      | 14    | _               | С           | 1100            |
|                             | 1101   | 13      | 15    | -               | D           | 1101            |
|                             | 1110   | 14      | 16    | _               | E           | 1110            |
|                             | 1111   | 15      | 17    |                 | F           | 1111            |

If a binary number contains digits to the right of the binary point, we can convert them to octal or hexadecimal by starting at the binary point and working right. Both the left-hand and right-hand sides can be padded with zeroes to get multiples of three or four bits, as shown in the example below:

$$10.1011001011_2 = 010.101100101100_2 = 2.5454_8$$
  
= 0010.101100101100\_2 = 2.B2C\_{16}

0

Converting in the reverse direction, from octal or hexadecimal to binary, is very easy. We simply replace each octal or hexadecimal digit with the corresponding 3- or 4-bit string, as shown below:

 $1357_8 = 001\ 011\ 101\ 111_2$   $2046.17_8 = 010\ 000\ 100\ 110\ 001\ 111_2$   $BEAD_{16} = 1011\ 1110\ 1010\ 1101_2$  $9F.46C_{16} = 1001\ 111\ 0100\ 0110\ 1100_2$ 

The octal number system was quite popular 25 years ago because of certain minicomputers that had their front-panel lights and switches arranged in groups of three. However, the octal number system is not used much today, because of the preponderance of machines that process 8-bit *bytes*. It is difficult to extract individual byte values in multibyte quantities in the octal representation; for

example, what are the octal values of the four 8-bit bytes in the 32-bit number with octal representation  $12345670123_8$ ?

In the hexadecimal system, two digits represent an 8-bit byte, and 2n digits represent an *n*-byte word; each pair of digits constitutes exactly one byte. For example, the 32-bit hexadecimal number 5678ABCD<sub>16</sub> consists of four bytes with values 56<sub>16</sub>, 78<sub>16</sub>, AB<sub>16</sub>, and CD<sub>16</sub>. In this context, a 4-bit hexadecimal digit is sometimes called a *nibble*; a 32-bit (4-byte) number has eight nibbles. Hexadecimal numbers are often used to describe a computer's memory address space. For example, a computer with 16-bit addresses might be described as having read/write memory installed at addresses 0–EFFF<sub>16</sub>, and read-only memory at addresses F000–FFFF<sub>16</sub>. Many computer programming languages use the prefix "0x" to denote a hexadecimal number, for example, 0×BFC0000.

| Conversion     | Method       | Example                                                                                                                                                                                                                                                                                                                      |
|----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Binary to      |              |                                                                                                                                                                                                                                                                                                                              |
| Octal          | Substitution | $10111011001_2 = 10 \ 111 \ 011 \ 001_2 = 2731_8$                                                                                                                                                                                                                                                                            |
| Hexadecimal    | Substitution | $10111011001_2 = 101 1101 1001_2 = 5D9_{16}$                                                                                                                                                                                                                                                                                 |
| Decimal        | Summation    | $10111011001_{2} = 1 \cdot 1024 + 0 \cdot 512 + 1 \cdot 256 + 1 \cdot 128 + 1 \cdot 64 + 0 \cdot 32 + 1 \cdot 164 + 1 \cdot 8 + 0 \cdot 4 + 0 \cdot 2 + 1 \cdot 1 = 1497_{10}$                                                                                                                                               |
| Octal to       |              |                                                                                                                                                                                                                                                                                                                              |
| Binary         | Substitution | $1234_8 = 001 \ 010 \ 011 \ 100_2$                                                                                                                                                                                                                                                                                           |
| Hexadecimal    | Substitution | $1234_8 = 001\ 010\ 011\ 100_2 = 0010\ 1001\ 1100_2 = 29C_{16}$                                                                                                                                                                                                                                                              |
| Decimal        | Summation    | $1234_8 = 1 \cdot 512 + 2 \cdot 64 + 3 \cdot 8 + 4 \cdot 1 = 668_{10}$ How??                                                                                                                                                                                                                                                 |
| Hexadecimal to |              |                                                                                                                                                                                                                                                                                                                              |
| Binary         | Substitution | $CODE_{16} = 1100\ 0000\ 1101\ 1110_2$                                                                                                                                                                                                                                                                                       |
| Octal          | Substitution | $CODE_{16} = 1100\ 0000\ 1101\ 1110_2 = 1\ 100\ 000\ 011\ 011\ 110_2 = 14033$                                                                                                                                                                                                                                                |
| Decimal        | Summation    | $C0DE_{16} = 12 \cdot 4096 + 0 \cdot 256 + 13 \cdot 16 + 14 \cdot 1 = 49374_{10}$                                                                                                                                                                                                                                            |
| Decimal to     |              |                                                                                                                                                                                                                                                                                                                              |
| Binary         | Division     | $108_{10} \div 2 = 54 \text{ remainder 0}  (\text{LSB})$<br>$\div 2 = 27 \text{ remainder 0}$<br>$\div 2 = 13 \text{ remainder 1}$<br>$\div 2 = 6 \text{ remainder 1}$<br>$\div 2 = 3 \text{ remainder 0}$<br>$\div 2 = 1 \text{ remainder 1}$<br>$\div 2 = 0 \text{ remainder 1}  (\text{MSB})$<br>$108_{10} = 1101100_{2}$ |
| Octal          | Division     | $108_{10} \div 8 = 13 \text{ remainder 4}  (\text{least significant digit}) \\ \div 8 = 1 \text{ remainder 5} \\ \div 8 = 0 \text{ remainder 1}  (\text{most significant digit}) \\ 108_{10} = 154_8$                                                                                                                        |
| Hexadecimal    | Division     | $108_{10} \div 16 = 6 \text{ remainder } 12  (\text{least significant digit}) \\ \div 16 = 0 \text{ remainder } 6  (\text{most significant digit}) \\ 108_{10} = 6C_{16}$                                                                                                                                                    |

| Table -2 | Conversion methods for | or common radices. |
|----------|------------------------|--------------------|
|----------|------------------------|--------------------|

# Arithmetic: Decimal Addition/Subtraction

Use decimal number line:

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
|--|---|---|---|---|---|---|---|---|---|---|
|--|---|---|---|---|---|---|---|---|---|---|

0+1 = 1; 1+1 = 2; 2+1 = 3; 3+1 = 4; 4+1 = 5; 5+1 = 6; 6+1 = 7; 7+1 = 8; 8+1=9; 9+1=10 0+2 = 2; 1+4 = 5; 2+6 = 8; 3+5 = 8; 4+5 = 9; 5+2 = 7; 6+1 = 7; 7+2 = 9; 8+0=8; 9+2=11

9-2 = 7; 8-4 = 4; 2-6 = -4; 3-5 = -2; 4-5 = -1; 5-2 = 3; 6-1 = 5; 7-5 = 9; 8-8=0; 9-2=7

Sample additions:

1 1 7920711.716+ 234020.019 8154731.735

# Arithmetic: Binary Addition/Subtraction

### Use binary number line:

0 1 0+1 = 1; 1+1 = 10; 10+1 = 11; 11+1 = 100; 1-1 = 0; 1-0 = 1; 11-1=10; 10-1=1; 0-1 = -1;

<u>Sample additions</u>: **11 1111 1** 1110111.111+ 111000.010 ------**1**0110000.001

# Arithmetic: Octal Addition/Subtraction

Use octal number line:

Use hevedecimal number line:

0 1 2 3 5 7 4 6 0+1 = 1; 1+1 = 2; 2+1 = 3; 3+1 = 4; 4+1 = 5; 5+1 = 6; 6+1 = 7; 7+1 = 10; 7+2=11; 7+3=12 0+2 = 2; 1+4 = 5; 2+6 = 10; 3+5 = 10; 4+5 = 11; 5+2 = 7; 6+1 = 7; 7+2 = 11; 11+7=20; 17+2=212-6 = -4; 3-5 = -2; 4-5 = -1; 5-2 = 3; 10-1 = 7; 11-2 = 7; 12-5=5; Sample addition: 1 1 1 1 6720711.716+ 234120.112 7155032.030

# **Arithmetic: Hex Addition/Subtraction**

| 030 | - IICA | aucon   | narna   | in der |          |         |          |          |      |        |     |        |     |       |   |
|-----|--------|---------|---------|--------|----------|---------|----------|----------|------|--------|-----|--------|-----|-------|---|
| 0   | 1      | 2       | 3       | 4      | 5        | 6       | 7        | 8        | 9    | Α      | В   | С      | D   | E     | F |
|     |        |         |         |        |          |         |          |          |      |        |     |        |     |       |   |
| 8+  | 1 = 9  | );9+    | 1 = A;  | A + 1  | L = B;   | B+1=    | = C; C + | · 1 = D; | D+1= | = E; E | +1= | = F; F | +1= | = 10; |   |
| 7+  | 4 = [  | 3;6+    | 6 = C;  | 5+5    | 5 = A; 4 | 4 + 7 = | = B; F + | 2 = 11;  | ;6+A | = 10;  |     |        |     |       |   |
| F-2 | 2 = D; | F-4 =   | B; E-6  | 5 = 8; | 3-F =    | -C; A-  | 5 = 5;   |          |      |        |     |        |     |       |   |
| Sar | nple a | additio | ons:    |        |          |         |          |          |      |        |     |        |     |       |   |
|     |        |         | 1       |        |          |         |          |          |      |        |     |        |     |       |   |
| BS  | 207    | 711.    | E 1 A - | F C    |          |         |          |          |      |        |     |        |     |       |   |
| 2   | 340    | 20.     | 019     |        |          |         |          |          |      |        |     |        |     |       |   |
|     |        |         |         | -      |          |         |          |          |      |        |     |        |     |       |   |
| BB  | 3547   | 731.    | E 3 3   |        |          |         |          |          |      |        |     |        |     |       |   |
|     |        |         |         |        |          |         |          |          |      |        |     |        |     |       |   |
| AB  | C.DEF  | +       |         |        |          |         |          |          |      |        |     |        |     |       |   |
| 012 | 2. 347 | 7       |         |        |          |         |          |          |      |        |     |        |     |       |   |
|     |        |         |         |        |          |         |          |          |      |        |     |        |     |       |   |
| AC  | F.13   | 6       |         |        |          |         |          |          |      |        |     |        |     |       |   |
|     |        |         |         |        |          |         |          |          |      |        |     |        |     |       |   |

## **Representation of Negative Numbers**

## Signed-Magnitude Representation

In the *signed-magnitude system*, a number consists of a magnitude and a symbol indicating whether the magnitude is positive or negative. Thus, we interpret decimal numbers +98, -57, +123.5, and -13 in the usual way, and we also assume that the sign is "+" if no sign symbol is written. There are two possible representations of zero, "+0" and "-0", but both have the same value.

The signed-magnitude system is applied to binary numbers by using an extra bit position to represent the sign (the *sign bit*). Traditionally, the most significant bit (MSB) of a bit string is used as the sign bit (0 = plus, 1 = minus), and the lower-order bits contain the magnitude. Thus, we can write several 8-bit signed-magnitude integers and their decimal equivalents:

| $01010101_2 = +85_{10}$  | $11010101_2 = -85_{10}$  |
|--------------------------|--------------------------|
| $01111111_2 = +127_{10}$ | $11111111_2 = -127_{10}$ |
| $00000000_2 = +0_{10}$   | $1000000_2 = -0_{10}$    |

The signed-magnitude system has an equal number of positive and negative integers. An *n*-bit signed-magnitude integer lies within the range  $-(2^{n-1}-1)$  through  $+(2^{n-1}-1)$ , and there are two possible representations of zero.

Practical design of digital logic circuit to add/sub signed magnitude numbers is complicated and is seldom undertaken.

## **One's (1's) Complement representation:**

The diminished radix-complement system for binary numbers is called the *ones'* complement. the most significant bit is the sign, 0 if positive and 1 if negative. Thus there are two representations of zero, positive zero  $(00\cdots00)$  and negative zero  $(11\cdots11)$ . Positive number representations are the same for both ones' and two's complements. However, negative number representations differ by 1. A weight of  $-(2^{n-1}-1)$ , rather than  $-2^{n-1}$ , is given to the most significant bit when computing the decimal equivalent of a ones'-complement number. The range of representable numbers is  $-(2^{n-1}-1)$  through  $+(2^{n-1}-1)$ . Some 8-bit numbers and their ones' complements are shown below:

$$17_{10} = 00010001_{2} \qquad -99_{10} = 10011100_{2} \qquad \downarrow \qquad 11101110_{2} = -17_{10} \qquad 01100011_{2} = 99_{10}$$

$$119_{10} = 01110111_{2} \qquad -127_{10} = 10000000_{2} \qquad \downarrow \qquad \downarrow \qquad 10001000_{2} = -119_{10} \qquad 01111111_{2} = 127_{10} \qquad 01111111_{2} = 127_{10} \qquad 0_{10} = 00000000_{2} \text{ (positive zero)} \qquad \downarrow \qquad 11111111_{2} = 0_{10} \text{ (negative zero)}$$

The main advantages of 1's complement are its symmetry and ease of implementation. But the adder design for 1's complement numbers is not easy. Also zero detectors in a 1's complement system must check for both representations of zero, or must always convert 11...11 to 00...00.

## Two's (2's) Complement representation:

For binary numbers, the radix complement is called the *two's complement*. The MSB of a number in this system serves as the sign bit; a number is negative if and only if its MSB is 1. The decimal equivalent for a two's-complement binary number is computed the same way as for an unsigned number, except that the weight of the MSB is  $-2^{n-1}$  instead of  $+2^{n-1}$ . The range of representable numbers is  $-(2^{n-1})$  through  $+(2^{n-1}-1)$ . Some 8-bit examples are shown below:

| 17 <sub>10</sub> =  | 000100012<br>↓ | complement bits | -99 <sub>10</sub> = | 100111012<br>↓ | complement bits |
|---------------------|----------------|-----------------|---------------------|----------------|-----------------|
|                     | 11101110       |                 |                     | 01100010       |                 |
| 11 <u>.</u>         | +1             | -               | 12                  | 11             | -               |
|                     | 111011112      | $= -17_{10}$    |                     | 011000112      | $= 99_{10}$     |
| 119 <sub>10</sub> = | 01110111       |                 | $-127_{10} =$       | 10000001       |                 |
| 6878                | ₽              | complement bits | 0.0248              | ₽              | complement bits |
|                     | 10001000       |                 |                     | 01111110       |                 |
| 2.5                 | +1             | 2               | 05                  | +1             | _               |
|                     | 100010012      | $= -119_{10}$   |                     | 011111112      | $= 127_{10}$    |

A carry out of the MSB position occurs in one case, . As in all two's-complement operations, this bit is ignored and only the low-order n bits of the result are used.

In the two's-complement number system, zero is considered positive because its sign bit is 0. Since two's complement has only one representation of zero, we end up with one extra negative number,  $-(2^{n-1})$ , that doesn't have a positive counterpart.

2's Complement numbers support sign extension. Most modern computers incorporate 2's complement system for subtraction.

# Exercise!!!

 1. Subtract 5 from 17 using 8-bit signed numbers in 2's complement representation. Validate ur answer.

```
    Sol:
```

```
17: 0 0010001+
```

- +5: 0 0000101
- -5: 1 1111010 (1's Complement) 1 1 1 11010+

1

-5: 1 1 1 1 1011 (2's Complement)

1 00001100 (+17 + -5)

 $0\,0\,0\,0\,1\,1\,0\,0 \rightarrow +\,12$ 

\* 2. Subtract 17 from 16 using 8-bit 2s' complement representation and validate ur answer.

## **Binary Coded Decimal Codes**

- Binary numbers or bits are most suited for internal computations of digital systems.
- But humans prefer decimal numbers (Why?)
- So, external interfaces of digital system may read or display decimal numbers.
- Also some digital devices process decimal numbers directly.
- So, to do this, a decimal digit is represented by a string of bits.
- Different combinations of bit values in the string represent different decimal digits.
- For example, using a 4-bit string, we represent decimal 0 · 0000, 1 · 0001, 2 · 0010, and so on.

- **Code** is defined as a set of n-bit strings in which diff string patterns represent diff numbers or other things.
- **Code word** is a particular combination of n-bit string value.
- There <u>may or may not be</u> an arithmetic relationship between the code word and the thing it represents.
- A Code that uses n-bit strings <u>need not</u> contain 2<sup>n</sup> valid code words.

# (8421) BCD Binary Coded Decimal (BCD) encodes the digits 0 thro' 9 by their 4-bit unsigned bin representations 0000 thro' 1001. The code words 1010 thro' 1111 are not used. BCD is a weighted code as each decimal digit can be obtained from its code word by putting a fixed weight (2<sup>3</sup>=8, 2<sup>2</sup>=4, 2<sup>1</sup>=2,2<sup>0</sup>=1) for each code word bit. Place 2 BCD Digits in one 8-bit byte in <u>Packed BCD</u> representation.

- So one byte represents values from 0 to 99 in packed BCD repr as opposed to 0 to 255 for unsigned 8-bit binary num.
- BCD numbers with any desired number of digits can be got by using one byte for each two digits.

| Decimal digit | BCD (8421) |
|---------------|------------|
| 0             | 0000       |
| 1             | 0001       |
| 2             | 0010       |
| 3             | 0011       |
| 4             | 0100       |
| 5             | 0101       |
| 6             | 0110       |
| 7             | 0111       |
| 8             | 1000       |
| 9             | 1001       |
|               |            |
|               | 1010       |
| -             | 1011       |
|               | 1100       |
| 201           | 1101       |
| 1 Star        | 1110       |
|               | 1111       |



| Ac   | lditions of BCD digit | s (Use co | prrection of 6)     |
|------|-----------------------|-----------|---------------------|
| 5    | 0101                  | 4         | 0100                |
| + 9  | + 1001                | + 5       | + 0101              |
| 14   | 1110                  | 9         | 1001                |
|      | + 0110 - correction   |           |                     |
| 10+4 | 1 0100                |           |                     |
| 8    | 1000                  | 9         | 1001                |
| + 8  | + 1000                | + 9       | + 1001              |
| 16   | 1 0000                | 18        | 1 0010              |
|      | + 0110 - correction   |           | + 0110 — correction |
| 10+6 | 1 0110                | 10+8      | 1 1000              |
|      |                       |           |                     |
|      |                       |           |                     |

## 2421 Code

- This is also a <u>weighted code</u> having weights 2,4,2 and 1 for the code word bits from msb.
- The advantage of this code is that it is <u>self-complementing</u>, i.e., the code word for the 9's complement can be got by flipping the individual bits of the code word.

| Decimal digit | BCD (8421) | 2421 |
|---------------|------------|------|
| 0             | 0000       | 0000 |
| 1             | 0001       | 0001 |
| 2             | 0010       | 0010 |
| 3             | 0011       | 0011 |
| 4             | 0100       | 0100 |
| 5             | 0101       | 1011 |
| 6             | 0110       | 1100 |
| 7             | 0111       | 1101 |
| 8             | 1000       | 1110 |
| 9             | 1001       | 1111 |
|               | 1010       | 0101 |
|               | 1011       | 0110 |
|               | 1100       | 0111 |
|               | 1101       | 1000 |
|               | 1110       | 1001 |
|               | 1111       | 1010 |

## **Excess-3 Code**

- This is an <u>unweighted</u> code.
- The code word for a decimal digit is got by adding 0011<sub>2</sub> to the corresponding BCD code word.
- As the code words follow a standard binary counting sequence, <u>standard binary counters</u> can easily be made to count in excess-3 code.
- This is also a <u>self-complementing</u> code.

|               | Decimal cod | es.    |              |
|---------------|-------------|--------|--------------|
| Decimal digit | BCD (8421)  | 2421   | Excess-3     |
| 0             | 0000        | 0000   | 0011         |
| 1             | 0001        | 0001   | 0100         |
| 2             | 0010        | 0010   | 0101         |
| 3             | 0011        | 0011   | 0110         |
| 4             | 0100        | 0100   | 0111         |
| 5             | 0101        | 1011   | 1000         |
| 6             | 0110        | 1100   | 1001         |
| 7             | 0111        | 1101   | 1010         |
| 8             | 1000        | 1110   | 1011         |
| 9             | 1001        | 1111   | 1100         |
|               |             | Unused | d code words |
|               | 1010        | 0101   | 0000         |
|               | 1011        | 0110   | 0001         |
|               | 1100        | 0111   | 0010         |
|               | 1101        | 1000   | 1101         |
|               | 1110        | 1001   | 1110         |
|               | 1111        | 1010   | 1111         |

| Gra                                                                                             | y Code                                   |                                 |                     |
|-------------------------------------------------------------------------------------------------|------------------------------------------|---------------------------------|---------------------|
| <ul> <li>A Digital Code in wh<br/><u>changes</u> between a<br/>words is called a Gra</li> </ul> | ich there is<br>pair of succ<br>ay Code. | s <u>only one</u><br>cessive co | <u>e bit</u><br>ode |
| • Eg. 3-bit Gray code                                                                           | Decimal<br>number                        | Binary<br>code                  | Gray<br>code        |
|                                                                                                 | 0                                        | 000                             | 000                 |
| <ul> <li>Is Gray Code a</li> </ul>                                                              | 1                                        | 001                             | 001                 |
| is druy couc u                                                                                  | 2                                        | 010                             | 011                 |
| Weighted code?                                                                                  | 3                                        | 011                             | 010                 |
|                                                                                                 | 4                                        | 100                             | 110                 |
|                                                                                                 | 5                                        | 101                             | 111                 |
|                                                                                                 | 6                                        | 110                             | 101                 |
|                                                                                                 | 7                                        | 111                             | 100                 |

| Gray Code    |                       |
|--------------|-----------------------|
| Gray<br>Code | Decimal<br>Equivalent |
| 0000         | 0                     |
| 0001         | 1                     |
| 0011         | 2                     |
| 0010         | 3                     |
| 0110         | 4                     |
| 0111         | 5                     |
| 0101         | 6                     |
| 0100         | 7                     |
| 1100         | 8                     |
| 1101         | 9                     |
| 1111         | 10                    |
| 1110         | 11                    |
| 1010         | 12                    |
| 1011         | 13                    |
| 1001         | 14                    |
| 1000         | 15                    |

- The Gray code is used in applications where normal sequence of binary number generated by hardware <u>produce an error</u> during transition from one number to the next.
- If binary numbers are used, a change from 0111 to 1000 may produce an <u>intermediate</u> <u>error</u> number 1001, if lsb takes longer to change than do the values of the other three bits.
- This could have <u>serious issues</u> for the machine.
- The Gray code eliminates this problem, since <u>only one bit changes</u> its value during any transition between two numbers.



|          | b7b6b5 |     |     |     |     |     |     |     |  |
|----------|--------|-----|-----|-----|-----|-----|-----|-----|--|
| b4b3b2b1 | 000    | 001 | 010 | 011 | 100 | 101 | 110 | 111 |  |
| 0000     | NUL    | DLE | SP  | 0   | 0   | Р   |     | р   |  |
| 0001     | SOH    | DC1 | !   | 1   | A   | Q   | а   | q   |  |
| 0010     | STX    | DC2 | **  | 2   | в   | R   | ь   | r   |  |
| 0011     | ETX    | DC3 | #   | 3   | С   | S   | с   | s   |  |
| 0100     | EOT    | DC4 | \$  | 4   | D   | Т   | d   | t   |  |
| 0101     | ENQ    | NAK | %   | 5   | E   | U   | e   | u   |  |
| 0110     | ACK    | SYN | &   | 6   | F   | v   | f   | v   |  |
| 0111     | BEL    | ETB | "   | 7   | G   | W   | g   | w   |  |
| 1000     | BS     | CAN | (   | 8   | н   | X   | h   | x   |  |
| 1001     | HT     | EM  | )   | 9   | I   | Y   | i   | У   |  |
| 1010     | LF     | SUB | *   | :   | J   | Z   | j   | z   |  |
| 1011     | VT     | ESC | +   | ;   | K   | [   | k   | (   |  |
| 1100     | FF     | FS  | ,   | <   | L   | ١   | 1   | 1   |  |
| 1101     | CR     | GS  | -   | =   | M   | ]   | m   | }   |  |
| 1110     | SO     | RS  |     | >   | N   | Λ   | n   | ~   |  |
| 1111     | SI     | US  | 1   | ?   | 0   | -   | 0   | DEL |  |

| Control Characters |                     |     |                           |
|--------------------|---------------------|-----|---------------------------|
| NUL                | Null                | DLE | Data-link escape          |
| SOH                | Start of heading    | DC1 | Device control 1          |
| STX                | Start of text       | DC2 | Device control 2          |
| ETX                | End of text         | DC3 | Device control 3          |
| EOT                | End of transmission | DC4 | Device control 4          |
| ENQ                | Enquiry             | NAK | Negative acknowledge      |
| ACK                | Acknowledge         | SYN | Synchronous idle          |
| BEL                | Bell                | ETB | End-of-transmission block |
| BS                 | Backspace           | CAN | Cancel                    |
| TH                 | Horizontal tab      | EM  | End of medium             |
| LF                 | Line feed           | SUB | Substitute                |
| VT                 | Vertical tab        | ESC | Escape                    |
| FF                 | Form feed           | FS  | File separator            |
| CR                 | Carriage return     | GS  | Group separator           |
| SO                 | Shift out           | RS  | Record separator          |
| SI                 | Shift in            | US  | Unit separator            |
| SP                 | Space               | DEL | Delete                    |




### **Basics of Error Correction**

- After an error is detected ,need to correct it!
- Make request for retransmission of the message on the assumption that the error was random and will not occur again.
- If the receiver detects a parity error, it sends back the ASCII NAK (negative acknowledge) control character consisting of an even parity eight bits 10010101.
- If no error is detected, the receiver sends back an ACK (acknowledge) control character, namely, 00000110.

# **Basics of Error Correction**

- The sending end will respond to an NAK by transmitting the message again until the correct parity is received.
- If, after a number of attempts, the transmission is still in error, a message can be sent to the operator to check for <u>malfunctions</u> in the transmission path.

## Introduction to Verilog programming...

- Verilog HDL(Hardware Description Language) was invented by *Phil Moorby* and *Prabhu Goel* around 1984.
- It served as a proprietary hardware modeling language owned by Gateway Design Automation Inc. ...
- In 2001, extensions to **Verilog**-95 were submitted back to IEEE and became IEEE standard 1364-2001, known as **Verilog**-2001.

- In 1990, Gateway Design Automation Inc. was acquired by Cadence Design System, which is now one of the biggest suppliers of electronic design technologies and engineering services in the electronic design automation (EDA) industry.
- Cadence recognized the value of Verilog, and realized that if **Verilog** remained as a closed language, the pressure of standardization would eventually drive people to shift to **VHDL**.
- So in 1991 the **Open Verilog International** (OVI) (now known as **Accellera**) was organized by Cadence and the documentation of Verilog was transferred to public domain under the name of OVI.
- It was later submitted to IEEE and became IEEE standard 1364-1995, commonly referred as Verilog-95.

Verilog of the 20<sup>th</sup> Century ....

- In 2001, extensions to Verilog-95 were submitted back to IEEE and became IEEE standard 1364-2001, known as Verilog-2001.
- The extensions covered some deficiencies that users had found in Verilog-95.
- One of the most significant upgrades was that signed variables (in 2's complement) became supported.
- Verilog-2001 is now dominant edition of Verilog supported by most design tools.
- In 2005, Verilog-2005 (IEEE Standard 1364-2005) was published with minor corrections and modifications.
- Also in 2005 **System Verilog**, a superset of **Verilog-2005**, with many new features and capabilities to aid design verification, was published.
- As of 2009, System Verilog and Verilog language standards were merged into **System Verilog 2009 (IEEE Standard 1800-2009)**, which is one of the most popular languages for IC design and verification today.
- Xilinx<sup>®</sup> Vivado Design Suite, released in 2013, can support System Verilog for FPGA design and verification.
- At our famed worthy NCERC Labs, we are devout followers of the same...

#### Verilog of the 21<sup>st</sup> Century ....



### Data Types

- Verilog has two main groups of data types: the *variable* data type and the *net* data type.
- These two groups differ in the way that they are assigned and hold values.
- They also represent different hardware structures.
- The *net* data types can represent physical connections between structural entities, such as gates.
- Generally, it does not store values.
- Instead, its value is determined by the values of its drivers, such as a continuous assignment or a gate.
- A very popular *net* data type is the **wire**.
- There are also several other predefined data types that are part of nets.
- Examples are tri (for tri-state), wand (for wired and), wor (for wired or).



|           | Predefined Types                                                                                                      |
|-----------|-----------------------------------------------------------------------------------------------------------------------|
| nets      | connections between hardware elements<br>(declared with keywords such as wire)                                        |
| variables | data storage elements that can retain values<br>(declared with the keywords such as reg)                              |
| integer   | an integer is a variable data type<br>(declared with the keyword <b>integer</b> )                                     |
| real      | real number constants and real variable data types for floating-point number (declared with the keyword real)         |
| time      | a special variable data type to store time information (declared with the keyword time)                               |
| vectors   | wire or reg data types can be declared as vectors (multiple bits)<br>(vectors can be declared with [range1 : range2]) |



| Verilog Operators |                                                                              |  |  |  |  |
|-------------------|------------------------------------------------------------------------------|--|--|--|--|
| 1. Unary sign     | and reduction operators:                                                     |  |  |  |  |
| + -               | Unary sign operators                                                         |  |  |  |  |
| &                 | Reduction and (unary operator to and bits in a vector and reduce to one bit) |  |  |  |  |
| ~&                | Reduction NAND                                                               |  |  |  |  |
| I                 | Reduction or (unary operator to or bits in a vector and reduce to one bit)   |  |  |  |  |
| ~                 | Reduction NOR                                                                |  |  |  |  |
| ٨                 | Reduction XOR                                                                |  |  |  |  |
| ~^ or ^~          | Reduction XNOR                                                               |  |  |  |  |
| !                 | Logical negation                                                             |  |  |  |  |
| ~                 | Bit-wise negation                                                            |  |  |  |  |
|                   |                                                                              |  |  |  |  |

| **           | Arithmetic (POWER)                  |
|--------------|-------------------------------------|
| 3. Arithmet  | ic: Multiplying, Modulus operators: |
| *            | Multiply                            |
| 1            | Divide                              |
| %            | Modulus                             |
| 4. Arithmet  | ic: Addition:                       |
| +            | Add                                 |
| -            | Subtract                            |
| 5. Shift ope | rators:                             |
| <<           | Logical left shift                  |
| >>           | Logical right shift                 |
| <<<          | Arithmetic left shift               |
| >>>          | Arithmetic right shift              |

|    |                                    | U                  |                                   |
|----|------------------------------------|--------------------|-----------------------------------|
| 6  | . Relational ope                   | erators:           |                                   |
|    | >                                  | Greater than       |                                   |
|    | <                                  | Less than          |                                   |
|    | >=                                 | Greater than or e  | qual                              |
|    | <=                                 | Less than or equa  | ıl                                |
| 7  | . Logical and bi                   | twise operators: E | quality and inequality            |
|    | ==                                 | Logical equality   |                                   |
|    | !=                                 | Logical inequality | /                                 |
|    | ===                                | Case equality      |                                   |
|    | !==                                | Case inequality    |                                   |
| 8  | . Bitwise operat                   | ors:               |                                   |
|    | &                                  | Bit-wise and (bin  | ary operator)                     |
| 9  | <ul> <li>Logical and bi</li> </ul> | twise operators:   |                                   |
|    | ^                                  | Bit-wise exclusive | or (binary operator)              |
|    | ^~ or ~^                           | Bit-wise equivale  | nce (binary operator)             |
|    | I                                  | Bit-wise inclusive | or (binary operator)              |
| 10 | Logical and:                       |                    |                                   |
|    | &&                                 | Logical and        | 13. Concatenation and replication |
| 11 | . Logical or:                      |                    | A Concatenation                   |
|    | II                                 | Logical or         | {} concatenation                  |
| 12 | . Conditional                      |                    | {{}} Replication                  |
|    | ?:                                 | Conditional        |                                   |
|    |                                    |                    |                                   |



- Precedence order can be changed by using parentheses.
- The { } operator can be used to concatenate two vectors (or an element and a vector, or two elements) to form a longer vector.
- For example, {010, 1} is 0101 and {"ABC", "DEF"} is "ABCDEF"
- In expression where A, B, C, and D are vectors:
- ({A, ~B} | C >> 2 & D) == 110010
- Relational expression performing an *equality test*.
- It is not an assignment statement.
- To evaluate the expression inside (), operator precedence shows highest precedence for three operators in order: >>, &, |
- In order to evaluate |, one of the operands of | has to be obtained by concatenation, which forces expression inside concatenate to be evaluated and operators ~, { }, are applied before the | can be evaluated.

| In expression v<br>({A, ~B}                                                         | vhere A, B, C, and D<br>C >> 2 & D)                              | are vectors:<br>== 110010                                                                                                                                                           |
|-------------------------------------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| If $A = 110, B = 111$ , as follows:                                                 | C = 011000, and $D = 111011$ ,                                   | the computation proceeds                                                                                                                                                            |
| C >> 2                                                                              | = 000110                                                         | (shift right 2                                                                                                                                                                      |
| C >> 2 & D<br>~ B = 000<br>{A, ~ B}<br>({A, ~ B})   (C >> 2<br>[({A, ~ B}   C >> 2) | = 000010<br>= 110000<br>(&D) = 110010<br>(& D) == 110010] = TRUE | places)<br>(bit-wise and)<br>(bit-wise negate)<br>(concatenation)<br>(bit-wise or)<br>(the parentheses<br>force the equality)<br>test to be done<br>last and the<br>result is TRUE) |
|                                                                                     |                                                                  |                                                                                                                                                                                     |



- Equals (==) and not equals (!=) can be applied to almost any type.
- The other relational operators can be applied to many numeric as well as to some array types.
- For example, if A = 5 B = 4 and C = 3, the expression (A >= B) & (B <= C) evaluates to FALSE.</li>
- It is legal to use concatenate operator on the left side of the assignment.

- For example, {Carry, Sum} = A + B;
- It adds A and B and the result goes into Sum and Carry.
- The most significant bit (msb) of the result is assigned to Carry.
- Shift operators can be applied to signed and unsigned registers.
- One can declare a register to be signed/unsigned in the following manner:

```
reg signed [7:0] A = 8'hA5;//signed register A
// number 0xA5 is unsigned, size (8) but repr in A in signed form msb =1
```

```
reg [7:0] B = 8'hA5; //unsigned register B
// number 0xA5 is unsigned, size (8) repr in B in unsigned form
```

• The 'h indicates that the value is hex.

- If the register is unsigned, arithmetic and logic shifts do same operation.
- The following example illustrates the difference between signed and unsigned <u>shifts</u> on signed and unsigned data...

```
reg signed [7:0] A = 8'hA5; // A is signed 1010 0101
A >> 4 is 00001010 (shift right unsigned by 4, filled with 0).
A >>> 4 is 11111010 (shift right signed by 4, filled with sign
                    bit).
A << 4 is 01010000 (shift left unsigned, filled with 0).
A <<< 4 is 01010000 (shift left signed,
                                             filled with 0
                    irrespective of rightmost bit).
reg [7:0] B = 8'hA5; // B is unsigned 1010 0101
B >> 4 is 00001010
                      (shift right unsigned by 4, filled with 0)
B >>> 4 is 00001010
                      (shift right signed by 4, but B is unsigned,
                      filled with 0)
B << 4 is 01010000
                      (shift left unsigned, filled with 0)
B <<< 4 is 01010000
                      (shift left signed, filled with 0
                      irrespective of rightmost bit)
```



- The + and operators can be applied to any types, including integer or real numeric operands.
- When types are mixed, the expression selfevaluates to a type according to the types of the operands.
- If a and b are 16 bits each, (a + b) will evaluate to 16 bits.
- However, (a + b + 0) will evaluate to integer.
- If any operand is real, the result is real.
- If any operand is unsigned, the result is unsigned, regardless of the operator.

- When expressions are evaluated, if the operands are of unequal bit lengths and if one or both operands are unsigned, the smaller operand shall be <u>zero-extended</u> to the size of the larger operand.
- If both operands are signed, the smaller operand shall be <u>sign-extended</u> to the size of the larger operand.
- If constants need to be extended, signed constants are <u>sign-extended</u> and unsigned constants are <u>zero-extended</u>.
- The \* and / operators perform <u>multiplication</u> and <u>division</u> on integer or floating point operands.
- The \*\* operator raises an integer or floating-point number to an <u>integer power</u>.
- The % (modulus) operator calculates the <u>remainder</u> for integer operands.

| Keywords                                                                                                                                                                                  |                                                                                                                                                                                                           |                                                                                                                                                                                |                                                                                        |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--|--|
| always<br>and<br>assign<br>automatic<br>begin<br>case<br>casez<br>casez<br>deassign<br>default<br>defparam<br>design<br>disable<br>edge<br>else<br>end<br>endcase<br>endcase<br>endconfig | endfunction<br>endgenerate<br>endmodule<br>endprimitive<br>endspecify<br>endtable<br>endtask<br>event<br>for<br>force<br>forever<br>fork<br>function<br>generate<br>genvar<br>include<br>initial<br>inout | input<br>integer<br>join<br>localparam<br>module<br>nand<br>negedge<br>nmos<br>nor<br>not<br>or<br>output<br>parameter<br>pmos<br>posedge<br>primitive<br>specify<br>specparam | signed<br>task<br>time<br>real<br>realtime<br>reg<br>unsigned<br>wait<br>while<br>wire |  |  |  |







 Like scientific notation, floating-point numbers have a sign, mantissa (M), base (B), and exponent (E).

±M×B<sup>E</sup>









| ine leee i<br>co repres<br>llegal res<br>or exam<br>problema                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ent nun<br>ults.<br>ple, rep<br>itic in fle      | -point star<br>nbers such<br>presenting<br>oating-poin<br>ng one.      | the number zero is<br>notation because of                                                           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                  |                                                                        |                                                                                                     |
| Special care reserve                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | odes wi<br>ved for                               | th expone<br>these spec                                                | nts of all O's or all I's<br>cial cases.                                                            |
| Special care reserv                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | odes wi<br>ved for<br>Sign                       | th expone<br>these spec                                                | nts of all O's or all I's<br>cial cases.<br>Fraction                                                |
| Special contract of the second | odes wi<br>ved for<br>Sign<br>X                  | th expone<br>these spec                                                | nts of all O's or all I's<br>cial cases.<br>Fraction                                                |
| Special co<br>are reserv<br>Number<br>0<br>∞                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | odes wi<br>ved for<br><u>Sign</u><br>X<br>0      | th expone<br>these spec<br>Exponent<br>00000000<br>11111111            | nts of all O's or all I's<br>cial cases.<br><u>Fraction</u><br>000000000000000000000000000000000000 |
| Special contract of the second | odes wi<br>ved for<br><u>Sign</u><br>X<br>0<br>1 | th expone<br>these spec<br>Exponent<br>00000000<br>11111111<br>1111111 | nts of all O's or all I's<br>cial cases.<br><u>Fraction</u><br>000000000000000000000000000000000000 |

# Boolean Postulates and Fundamental Gates

Module - 2 ECT 203

# Boolean Algebra

- In 1849 George Boole published a scheme for the algebraic description of processes involved in logical thought and reasoning.
- This scheme and its further refinements became known as **Boolean algebra**.
- It was almost 100 years later that this Algebra found application in the Engineering sense.
- In the late 1930s, Claude Shannon showed that Boolean Algebra provides an effective means of describing circuits built with switches.
- The Algebra can be used to describe logic circuits.
- A Boolean variable can take value of either logic 0 or logic 1.



| Postu<br>17-1812-10<br>00-11-1812-10 | Postulates and Theorems of<br>Boolean Algebra 1849<br>George Boole |                                 |  |  |  |
|--------------------------------------|--------------------------------------------------------------------|---------------------------------|--|--|--|
| Postulate/Theorem                    | Rule -a                                                            | rule-b                          |  |  |  |
| Postulate 2                          | x + 0 = x                                                          | × .1 = x                        |  |  |  |
| Postulate 5                          | x + x' = 1                                                         | $\sum_{i=1}^{n} x \cdot x' = 0$ |  |  |  |
| Theorem 1                            | x + x = x                                                          | <b>ö</b> x.x=x                  |  |  |  |
| Theorem 2                            | x + 1 = 1                                                          | <b>u</b> x . 0 = 0              |  |  |  |
| Theorem 3, Involution                | (x')' = x                                                          | Icip                            |  |  |  |
| Postulate 3, Commutative             | x + y = y + x                                                      | x.y = y.x                       |  |  |  |
| Theorem 4, Associative               | x + (y + z) = (x + y) + z                                          | x.(y.z) = (x.y).z               |  |  |  |
| Postulate 4, Distributive            | x.(y + z) = x.y + x.z                                              | x + y.z = (x + y).(x + z)       |  |  |  |
| Theorem 5, DeMorgan                  | (x + y)' = x'. y'                                                  | (x.y)' = x' + y'                |  |  |  |
| Theorem 6, Absorption                | x + x.y = x                                                        | x.(x + y) = x                   |  |  |  |

| Proofofthe Theor                       | e m s          |
|----------------------------------------|----------------|
| <b>THEOREM 1(a):</b> $x + x = x$ .     |                |
| Statement                              | Justification  |
| $x + x = (x + x) \cdot 1$              | postulate 2(b) |
| = (x + x)(x + x')                      | 5(a)           |
| = x + xx'                              | 4(b)           |
| = x + 0                                | 5(b)           |
| = x                                    | 2(a)           |
| <b>THEOREM 1(b):</b> $x \cdot x = x$ . |                |
| Statement                              | Justification  |
| $x \cdot x = xx + 0$                   | postulate 2(a) |
| = xx + xx'                             | 5(b)           |
| = x(x + x')                            | 4(a)           |
| $= x \cdot 1$                          | 5(a)           |
| = x                                    | 2(b)           |



**THEOREM 2(a):** x + 1 = 1.

| Statement                 | Justification  |
|---------------------------|----------------|
| $x + 1 = 1 \cdot (x + 1)$ | postulate 2(b) |
| = (x + x')(x + 1)         | 5(a)           |
| $= x + x' \cdot 1$        | 4(b)           |
| = x + x'                  | 2(b)           |
| = 1                       | 5(a)           |

**THEOREM 2(b):**  $x \cdot 0 = 0$  by duality.

**THEOREM 3:** (x')' = x. From postulate 5, we have x + x' = 1 and  $x \cdot x' = 0$ , which together define the complement of x. The complement of x' is x and is also (x')'.

- Therefore, since the complement is unique, we have (x')' = x.
- The theorems involving two or three variables may be proven algebraically from postulates and theorems that have already been proven.

THEOREM 6(a): x + xy = x.StatementJustification $x + xy = x \cdot 1 + xy$ postulate 2(b)= x(1 + y)4(a)= x(y + 1)3(a) $= x \cdot 1$ 2(a)= x2(b)THEOREM 6(b): x(x + y) = x by duality.























Simplify the following Boolean functions to a minimum number of literals.

1. 
$$x(x' + y) = xx' + xy = 0 + xy = xy$$
.  
2.  $x + x'y = (x + x')(x + y) = 1(x + y) = x + y$ .  
3.  $(x + y)(x + y') = x + xy + xy' + yy' = x(1 + y + y') = x$ .  
4.  $xy + x'z + yz = xy + x'z + yz(x + x')$   
 $= xy + x'z + xyz + x'yz$   
 $= xy(1 + z) + x'z(1 + y)$   
 $= xy + x'z$ .  
5.  $(x + y)(x' + z)(y + z) = (x + y)(x' + z)$ , by duality from function 4.

Find the complement of the functions  $F_1 = x'yz' + x'y'z$  and  $F_2 = x(y'z' + yz)$ . By applying DeMorgan's theorems as many times as necessary, the complements are obtained as follows:

$$F'_{1} = (x'yz' + x'y'z)' = (x'yz')'(x'y'z)' = (x + y' + z)(x + y + z')$$

$$F'_{2} = [x(y'z' + yz)]' = x' + (y'z' + yz)' = x' + (y'z')'(yz)'$$

$$= x' + (y + z)(y' + z')$$

$$= x' + yz' + y'z$$





- In a similar fashion, n variables forming an OR term, provide 2<sup>n</sup> possible combinations, called <u>Maxterms</u>, or standard sums.
- Each <u>Maxterm</u> is obtained from an OR term of the *n* variables, with each variable being unprimed if the corresponding bit is a 0 and primed if a 1.
- Each Maxterm is the complement of its corresponding minterm and vice versa.
- A Boolean function can be expressed algebraically from a given truth table by forming a minterm for each combination of the variables that produces a 1 in the function and then taking the OR of all those terms.

| x y |   |   | M      | Minterms       |  |
|-----|---|---|--------|----------------|--|
|     | Y | z | Term   | Designation    |  |
| 0   | 0 | 0 | x'y'z' | m <sub>0</sub> |  |
| 0   | 0 | 1 | x'y'z  | $m_1$          |  |
| 0   | 1 | 0 | x'yz'  | $m_2$          |  |
| 0   | 1 | 1 | x'yz   | $m_3$          |  |
| 1   | 0 | 0 | xy'z'  | $m_4$          |  |
| 1   | 0 | 1 | xy'z   | m5             |  |
| 1   | 1 | 0 | xyz'   | m <sub>6</sub> |  |
| 1   | 1 | 1 | xyz    | $m_7$          |  |

| x             | Y                           | z                             | Function f <sub>1</sub>                                    | Function f <sub>2</sub>                |
|---------------|-----------------------------|-------------------------------|------------------------------------------------------------|----------------------------------------|
| 0             | 0                           | 0                             | 0                                                          | 0                                      |
| 0             | 0                           | 1                             | 1                                                          | 0                                      |
| 0             | 1                           | 0                             | 0                                                          | 0                                      |
| 0             | 1                           | 1                             | 0                                                          | 1                                      |
| 1             | 0                           | 0                             | 1                                                          | 0                                      |
| 1             | 0                           | 1                             | 0                                                          | 1                                      |
| 1             | 1                           | 0                             | 0                                                          | 1                                      |
| 1             | 1                           | 1                             | 1                                                          | 1                                      |
| $f_1 = f_2 =$ | = x'y'z<br>x'yz +<br>Boolea | + xy'z<br>- xy'z -<br>in func | $x' + xyz = m_1 + xyz' + xyz' + xyz = m_1$ tion can be exp | $m_4 + m_7$<br>$m_3 + m_5 + m_6 + m_6$ |

Consider the complement of a Boolean function.
It may be read from the truth table by forming a minterm for each combination that produces a 0 in the function and then ORing those terms.
The complement of f<sub>1</sub> is read as: f'<sub>1</sub> = x'y'z' + x'yz' + x'yz + xy'z + xyz'
Take the complement of f<sub>1</sub>', to obtain the function f1: (Use <u>DeMorgan's rule</u>) f<sub>1</sub> = (x + y + z)(x + y' + z)(x' + y + z')(x' + y' + z) = M<sub>0</sub> · M<sub>2</sub> · M<sub>3</sub> · M<sub>5</sub> · M<sub>6</sub>

- Any Boolean function can be expressed as a product of Maxterms (with "product" meaning the ANDing of terms). **Product of Sums (POS).**
- The procedure for obtaining the product of Maxterms directly from the truth table is as follows:
- Form a Maxterm for each combination of the variables that produces a 0 in the function, and then form the AND of all those Maxterms.
- Boolean functions expressed as a sum of Minterms or product of Maxterms are said to be in *Canonical form*.





















- Each sum term in the standard POS expression is called a Maxterm.
- A function in two variables (A, B) has four possible Maxterms, (A'+B'),(A'+B),(A+B'),(A+B)
- They are represented as M<sub>0</sub>, M<sub>1</sub>, M<sub>2</sub>, and M<sub>3</sub>.
- The uppercase letter M stands for Maxterm and its subscript denotes the decimal designation of that Maxterm.
- Treat the non-complemented variable as a 0 and the complemented variable as a 1 and put them side by side for reading the decimal equivalent of the binary number so formed.
- For mapping a POS expression on to the K-map, 0s are placed in the squares corresponding to the Maxterms which are presented in the expression.
























• The NOT gate given by:

**not** (y, x); // implements y = x'.

- A logic circuit is specified in the form of a *module* that contains the statements that define the circuit.
- A module has inputs and outputs, which are referred to as its *ports*.
- The word port is a commonly-used term that refers to an input or output connection to an electronic circuit.





# Second example of Verilog code It defines a circuit that has four input signals, x<sub>1</sub>, x<sub>2</sub>, x<sub>3</sub>, and x<sub>4</sub>, and three output signals, f, g, and h. It implements the logic functions: g = x<sub>1</sub>.x<sub>3</sub> + x<sub>2</sub>.x<sub>4</sub> h = (x<sub>1</sub> + x<sub>3</sub>') (x<sub>2</sub>' + x<sub>4</sub>) f = g + h









# Combinatorial and Arithmetic Circuits

ECT 203 Module -3







- A combinational circuit can be specified with a truth table that lists the output values for each combination of input variables.
- A combinational circuit also can be described by *m* Boolean functions, one for each output variable.
- Each output function is expressed in terms of the *n* input variables.
- The most important standard combinational circuits, such as multiplexers, adders, subtractors, comparators, demultiplexers, decoders, encoders will be studied.
- These components are available in integrated circuits as medium-scale integration (MSI) circuits.
- They are also used as *standard cells* in complex very large scale integrated (VLSI) circuits such as Application-Specific Integrated Circuits (ASICs).
- The standard cell functions are interconnected within the VLSI circuit in the same way that they are used in multiple-IC MSI design.









- Magnitude comparison is usually done by computing A- B and looking at the sign (most significant bit) of the result, as shown in diagram.
- If the result is negative (i.e., the sign bit is 1), then A is less than B.
- Otherwise A is greater than or equal to B.





- A multiplexer circuit has a number of data inputs, one or more select inputs, and one output.
- It passes the signal value on one of the data inputs to the output.
- The data input is selected by the values of the select inputs.





- The *select* input, *s*, chooses as the output of the multiplexer either input *w*<sub>0</sub> or *w*<sub>1</sub>.
- The multiplexer's functionality can be described in the form of a truth table as shown in part (b) of the figure.
- Part(c) gives a sum-of-products implementation of the 2-to-1 multiplexer.

## 4-to-1 Multiplexer

- This is a larger multiplexer with four data inputs,  $w_0, \ldots, w_3$ , and two select inputs,  $s_1$  and  $s_0$ .
- As shown in the truth table in part (b) of the figure, the two-bit number represented by  $s_1s_0$  selects one of the data inputs as the output of the multiplexer.
- A sum-of-products implementation of the 4-to-1 multiplexer appears in part (c).
- It realizes the multiplexer function

 $f = \overline{s}_1 \overline{s}_0 w_0 + \overline{s}_1 s_0 w_1 + s_1 \overline{s}_0 w_2 + s_1 s_0 w_3$ 











### Synthesis of Logic Functions Using Multiplexers

- Multiplexers can also be used in a more general way to synthesize logic functions.
- <u>Example: 1</u>: Implement the Ex-OR function using multiplexer.

- Truth table defines function  $f = w1 \oplus w2$ .
- Implement with a 4-to-1 multiplexer where values of *f* in each row of truth table are connected to multiplexer data inputs.
- The multiplexer select inputs are w1 and w2.
- Thus for each valuation of w1w2, output *f* is equal to function value in corresponding row of truth table.
- The above implementation is straightforward, but it is not very efficient.

- A better implementation can be got by modifying truth table as shown in Figure *b*, which allows *f* to be implemented by a single 2-to-1 multiplexer.
- One of the input signals, w1, is chosen as select input of the 2-to-1 multiplexer.
- The truth table is redrawn to indicate the value of *f* for each value of *w*1.
- When w1 = 0, f has the same value as input w2, and when w1 = 1, f has the value of w2'.









- The function can be implemented using 2-to-1 multiplexers.
- When w1 = 0, f is equal to XOR of w2 and w3, and when w1 = 1, f is the XNOR of w2 and w3.
- Part (b) gives a corresponding circuit.
- The left multiplexer in the circuit produces  $w2 \oplus w3$
- The right multiplexer uses the value of w1 to select either w2 ⊕ w3 or its complement.
- This circuit can be got directly by writing the function as :
  - $f = (w2 \oplus w3) \oplus w1$







# Magnitude Comparator

- The comparison of two numbers is an operation that determines whether one number is greater than, less than, or equal to the other number.
- A magnitude comparator is a combinational circuit that compares two numbers A and B and determines their relative magnitudes.
- The outcome of the comparison is specified by three binary variables that indicate whether A > B, A = B, or A < B.</li>

### 4-bit Magnitude Comparator

- Consider two numbers, A and B, with four digits each.
- Write the coefficients of the numbers in descending order of significance:

 $A = A_3 A_2 A_1 A_0$   $B = B_3 B_2 B_1 B_0$ 

- The two numbers are equal if all pairs of significant digits are equal:  $A_3 = B_3, A_2 = B_2, A_1 = B_1$ , and  $A_0 = B_0$ .
- When the numbers are binary, the digits are either 1 or 0, and the equality of each pair of bits can be expressed logically with an exclusive-NOR function as:

$$x_i = A_i B_i + A'_i B'_i$$
 for  $i = 0, 1, 2, 3$ 

 where x<sub>i</sub> = 1 only if the pair of bits in position *i* are equal (i.e., if both are 1 or both are 0).

- The equality of the two numbers A and B is displayed in a combinational circuit by an output binary variable that we designate by the symbol (A = B)
- This binary variable is equal to 1 if the input numbers, A and B, are equal, and is equal to 0 otherwise.
- For equality to exist, all x<sub>i</sub> variables must be equal to 1, a condition that dictates an AND operation of all variables:

$$(A = B) = x_3 x_2 x_1 x_0$$

• The *binary* variable (A = B) is equal to 1 only if all pairs of digits of the two numbers are equal.

- To determine whether A is greater or less than B, inspect the relative magnitudes of pairs of significant digits, starting from the MSB.
- If the two digits of a pair are equal, compare the next lower significant pair of digits.
- The comparison continues until a pair of unequal digits is reached.
- If the corresponding digit of A is 1 and that of B is
   0, conclude that A > B.
- If the corresponding digit of A is 0 and that of B is
   1, then A < B.</li>



$$(A > B) = A_3B'_3 + x_3A_2B'_2 + x_3x_2A_1B'_1 + x_3x_2x_1A_0B'_0$$
  
(A < B) = A'\_3B\_3 + x\_3A'\_2B\_2 + x\_3x\_2A\_1'B\_1 + x\_3x\_2x\_1A\_0'B\_0

 The symbols (A > B) and (A < B) are *binary* output variables that are equal to 1 when A > and A < B, respectively.



### Decoder

- A binary code of *n* bits is capable of representing up to 2<sup>*n*</sup> distinct elements of coded information.
- A *decoder* is a combinational circuit that converts binary information from *n* input lines to a maximum of 2<sup>n</sup> unique output lines.
- If the *n*-bit coded information has unused combinations, the decoder may have fewer than 2<sup>n</sup> outputs.

- The decoders presented here are called *n* -to*m* -line decoders, where  $m \le 2^n$ .
- Their purpose is to generate the 2<sup>n</sup> (or fewer) minterms of *n* input variables.
- Each combination of inputs will assert a unique output.
- The name *decoder* is also used in conjunction with other code converters, such as a BCD-to-seven-segment decoder.





















# **Priority Encoders**

- Another useful class of encoders is based on the priority of input signals.
- In a *priority encoder* each input has a priority level associated with it.
- The encoder outputs indicate the active input that has the highest priority.
- When an input with a high priority is asserted, the other inputs with lower priority are ignored.
- The truth table for a 4-to-2 priority encoder is shown in diagram.

- It assumes that w0 has the lowest priority and w3 the highest.
- The outputs y1 and y0 represent the binary number that identifies the highest priority input set to 1.
- Since it is possible that none of the inputs is equal to 1, an output, *z*, is provided to indicate this condition.
- It is set to 1 when at least one of the inputs is equal to 1.
- It is set to 0 when all inputs are equal to 0.
- The outputs y1 and y0 are not meaningful in this case, and hence the first row of the truth table can be treated as a don't-care condition for y1 and y0.

| 5    | 0      | 0       | 0        | -1       | -0    | ~   |
|------|--------|---------|----------|----------|-------|-----|
| 0    | 0      | 0       | 0        | a        | a     | 0   |
| 0    | 0      | 0       | 1        | 0        | 0     | 1   |
| 0    | 0      | 1       | X        | 0        | 1     | 1   |
| 0    | 1      | Х       | Х        | 1        | 0     | 1   |
| 1    | Х      | х       | Х        | 1        | 1     | 1   |
| Trut | th tab | ole for | a 4-to-2 | priority | encod | er. |

| <ul> <li>The behavior of the priority encoder is most easily<br/>understood by first considering the last row in the truth<br/>table.</li> </ul>          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>It specifies that if input w3 is 1, then the outputs are<br/>set to y1y0 = 11.</li> </ul>                                                        |
| <ul> <li>Because w3 has the highest priority level, the values of<br/>inputs w2, w1, and w0 do not matter.</li> </ul>                                     |
| <ul> <li>To reflect the fact that their values are irrelevant, w2,<br/>w1, and w0 are denoted by the symbol x in the truth<br/>table.</li> </ul>          |
| <ul> <li>The second-last row in the truth table stipulates that</li> <li>if w2 = 1, then the outputs are set to y1y0 = 10, but only if w3 = 0.</li> </ul> |
| <ul> <li>Similarly, input w1 causes the outputs to be set to y1y0</li> <li>= 01 only if both w3 and w2 are 0.</li> </ul>                                  |
| <ul> <li>Input w0 produces the outputs y1y0 = 00 only if w0 is<br/>the only input that is asserted.</li> </ul>                                            |


















- The input variables designate the augend and addend bits;
- the output variables produce the sum and carry.
- We assign symbols x and y to the two inputs and S (for sum) and C (for carry) to the outputs.

| ۲<br>۲ | y | C | 2 |
|--------|---|---|---|
| 0      | 0 | 0 | 0 |
| 0      | 1 | 0 | 1 |
| 1      | 0 | 0 | 1 |
| 1      | 1 | 1 | 0 |





| ull Ad | dder |   |   |   |
|--------|------|---|---|---|
| x      | y    | z | C | S |
| 0      | 0    | 0 | 0 | 0 |
| 0      | 0    | 1 | 0 | 1 |
| 0      | 1    | 0 | 0 | 1 |
| 0      | 1    | 1 | 1 | 0 |
| 1      | 0    | 0 | 0 | 1 |
| 1      | 0    | 1 | 1 | 0 |
| 1      | 1    | 0 | 1 | 0 |
| 1      | 1    | 1 | 1 | 1 |







The S output from the second half adder is the exclusive-OR of z and the output of the first half adder, giving,

$$S = z \oplus (x \oplus y)$$
  
=  $z'(xy' + x'y) + z(xy' + x'y)'$   
=  $z'(xy' + x'y) + z(xy + x'y')$   
=  $xy'z' + x'yz' + xyz + x'y'z$ 

The carry output is,

$$C = z(xy' + x'y) + xy = xy'z + x'yz + xy$$

## **Binary Adder**

- A binary adder is a digital circuit that produces the arithmetic sum of two binary numbers.
- Full adders are connected in cascade, with the o/p carry from each full adder connected to the i/p carry of the next full adder in the chain.
- Addition of *n*-bit numbers requires a chain of *n* full adders.
- The input carry to lsb position is fixed at 0.



- Interconnection of four full-adder (FA) circuits to provide a four-bit binary ripple carry adder.
- The augend bits of *A* and the addend bits of *B* are designated by subscript numbers from right to left, with subscript 0 denoting the Lsb.
- The carries are connected in a chain through the full adders.
- The input carry to the adder is  $C_0$ , and it ripples through the full adders to the output carry  $C_4$ .
- The S outputs generate the required sum bits.
- An *n* -bit adder requires *n* full adders, with each output carry connected to the input carry of the next higher order full adder.

| Subscript <i>i</i> : | 3 | 2 | 1 | 0 |           |
|----------------------|---|---|---|---|-----------|
| Input carry          | 0 | 1 | 1 | 0 | $C_i$     |
| Augend               | 1 | 0 | 1 | 1 | $A_i$     |
| Addend               | 0 | 0 | 1 | 1 | $B_i$     |
| Sum                  | 1 | 1 | 1 | 0 | $-S_i$    |
| Output carry         | 0 | 0 | 1 | 1 | $C_{i+1}$ |

- The bits are added with full adders, starting from lsb, to form the sum bit and carry bit.
- The input carry  $C_0$  in the lsb must be 0.
- The value of  $C_{i+1}$  in a given significant position is the output carry of the full adder.
- This value is transferred into the input carry of the full adder that adds the bits one higher significant position to the left.
- The sum bits are thus generated starting from the rightmost position and are available as soon as the corresponding previous carry bit is generated.
- All the carries must be generated for the correct sum bits to appear at the outputs.
- The four-bit adder is a typical example of a standard component.
- It can be used in many applications involving arithmetic operations.





- The input carry CO must be equal to 1 when subtraction is performed.
- The operation thus performed becomes *A*, plus the 1's complement of *B*, plus 1.
- This is equal to A plus the 2's complement of B
- For unsigned numbers, that gives A B if  $A \ge B$  or the 2's complement of B A if A < B.
- For signed numbers, the result is A B, provided that there is no overflow.



- The add and sub operations can be combined into one circuit with one common binary adder by including an ex-OR gate with each full adder.
- A four-bit adder–subtractor circuit is shown.
- The mode input *M* controls the operation.
- When M = 0, circuit is an adder, and when M = 1, circuit becomes a subtractor.
- Each ex-OR gate receives input *M* and one of i/ps of *B*.
- When M = 0, we have  $B \bigoplus 0 = B$ .
- The full adders receive the value of *B*, the i/p carry is 0, and the circuit performs *A* plus *B*.
- When M = 1, we have  $B \bigoplus 1 = B$  and  $C_0 = 1$ .
- The *B* i/ps are all inverted and a 1 is added thro' i/p carry.
- The circuit performs the operation A plus the 2's complement of B.
- The ex-OR with output *V* is for detecting an overflow.



- The detection of an overflow after addition of numbers depends on whether the numbers are signed or unsigned.
- When two <u>unsigned numbers</u> are added, an overflow is detected from the end carry out of the msb.
- In the case of <u>signed numbers</u>, two details are important:
  - the leftmost bit always represents the sign, and
  - negative numbers are in 2's-complement form.
- When two <u>signed numbers</u> are added, the sign bit is treated as part of the number and the end carry does not indicate an overflow.
- An overflow may occur if the two numbers added are both positive or both negative.

- An <u>overflow condition</u> can be detected by observing the <u>carry into</u> the sign bit position and the <u>carry out</u> of the sign bit position.
- If these two carries are not equal, an overflow has occurred.
- If the two carries are applied to an ex-OR gate, an <u>overflow is detected</u>, when the output of the gate is equal to 1.
- For this to work correctly, the 2's complement of a negative number must be computed by taking the 1's complement and adding 1.

# **BCD Adder**

- Consider the arithmetic addition of two decimal digits in BCD, together with an input carry from a previous stage.
- Since each input digit does not exceed 9, the output sum cannot be greater than 9 + 9 + 1 = 19, the 1 in the sum being an input carry.
- Suppose we apply two BCD digits to a four-bit binary adder.
- The adder will form the sum in *binary* and produce a result that ranges from 0 through 19.

| Binary Sum |                |                |                |    | BCD Sum |    |            |                |            | Decima |  |
|------------|----------------|----------------|----------------|----|---------|----|------------|----------------|------------|--------|--|
| K          | Z <sub>8</sub> | Z <sub>4</sub> | Z <sub>2</sub> | Z1 | c       | 58 | <b>S</b> 4 | S <sub>2</sub> | <b>S</b> 1 |        |  |
| 0          | 0              | 0              | 0              | 0  | 0       | 0  | 0          | 0              | 0          | 0      |  |
| 0          | 0              | 0              | 0              | 1  | 0       | 0  | 0          | 0              | 1          | 1      |  |
| 0          | 0              | 0              | 1              | 0  | 0       | 0  | 0          | 1              | 0          | 2      |  |
| 0          | 0              | 0              | 1              | 1  | 0       | 0  | 0          | 1              | 1          | 3      |  |
| 0          | 0              | 1              | 0              | 0  | 0       | 0  | 1          | 0              | 0          | 4      |  |
| 0          | 0              | 1              | 0              | 1  | 0       | 0  | 1          | 0              | 1          | 5      |  |
| 0          | 0              | 1              | 1              | 0  | 0       | 0  | 1          | 1              | 0          | 6      |  |
| 0          | 0              | 1              | 1              | 1  | 0       | 0  | 1          | 1              | 1          | 7      |  |
| 0          | 1              | 0              | 0              | 0  | 0       | 1  | 0          | 0              | 0          | 8      |  |
| 0          | 1              | 0              | 0              | 1  | 0       | 1  | 0          | 0              | 1          | 9      |  |
| 0          | 1              | 0              | 1              | 0  | 1       | 0  | 0          | 0              | 0          | 10     |  |
| 0          | 1              | 0              | 1              | 1  | 1       | 0  | 0          | 0              | 1          | 11     |  |
| 0          | 1              | 1              | 0              | 0  | 1       | 0  | 0          | 1              | 0          | 12     |  |
| 0          | 1              | 1              | 0              | 1  | 1       | 0  | 0          | 1              | 1          | 13     |  |
| 0          | 1              | 1              | 1              | 0  | 1       | 0  | 1          | 0              | 0          | 14     |  |
| 0          | 1              | 1              | 1              | 1  | 1       | 0  | 1          | 0              | 1          | 15     |  |
| 1          | 0              | 0              | 0              | 0  | 1       | 0  | 1          | 1              | 0          | 16     |  |
| 1          | 0              | 0              | 0              | 1  | 1       | 0  | 1          | 1              | 1          | 17     |  |
| 1          | 0              | 0              | 1              | 0  | 1       | 1  | 0          | 0              | 0          | 18     |  |
| 1          | 0              | 0              | 1              | 1  | 1       | 1  | 0          | 0              | 1          | 19     |  |

- These binary numbers are listed and are labeled by symbols *K*, *Z*<sub>8</sub>, *Z*<sub>4</sub>, *Z*<sub>2</sub>, and *Z*<sub>1</sub>.
- *K* is the carry, and the subscripts under the letter *Z* represent the weights 8, 4, 2, and 1 that can be assigned to four bits in BCD code.
- The columns under binary sum list the binary value that appears in the o/ps of the four-bit binary adder.
- The output sum of two decimal digits must be represented in BCD and should appear in the form listed in the columns under "BCD Sum."

- When the binary sum is equal to or less than 1001, the corresponding BCD number is identical, and so no conversion is needed.
- When the binary sum is greater than 1001, we obtain an invalid BCD representation.
- The addition of binary 6 (0110) to the binary sum converts it to the correct BCD value and also produces an output carry as required.
- The logic circuit that detects the necessary correction can be derived from the entries in the table.
- It is obvious that a correction is needed when the binary sum has an output carry K = 1.

- The other six combinations from 1010 through 1111 that need a correction have a 1 in position  $Z_8$ .
- To distinguish them from binary 1000 and 1001, which also have a 1 in position  $Z_8$ , specify that either  $Z_4$  or  $Z_2$  must have a 1.
- The condition for a correction and an output carry can be expressed by the Boolean function,

$$C = K + Z_8 Z_4 + Z_8 Z_2$$

• When C = 1, it is needed to add 0110 to binary sum and provide an o/p carry for next stage.



- The two decimal digits, together with the input carry, are first added in the <u>top four-bit adder</u> to produce the binary sum.
- When the output carry is equal to 0, nothing is added to the binary sum.
- When it is equal to 1, binary 0110 is added to the binary sum thro' the <u>bottom four-bit adder</u>.
- The output carry generated from bottom adder can be ignored, since it supplies information already available at the output carry terminal.
- A decimal parallel adder that adds *n* decimal digits needs *n* BCD adder stages.
- The o/p carry from one stage must be connected to the i/p carry of the next higher order stage.

# Gate Level Modelling of Combinational Logic in Verilog

ECT 203 Module - III (Cont...)

### Design of Arithmetic Circuits Using Verilog

- To implement the full-adder circuit that has the inputs  $C_{in}$ , x and y and produces the outputs s and  $C_{out}$ .
- One way of specifying this circuit in Verilog is to use the gate-level primitives
- Each of the three AND gates in the circuit is defined by a separate statement.
- Verilog allows combining such statements into a single statement.
- In this case, commas are used to separate the definition of each AND gate.









module fulladd (Cin, x, y, s, Cout);
input Cin, x, y;
output s, Cout;
assign s = x ^ y ^ Cin;
assign Cout = (x & y) | (x & Cin) | (y & Cin);
endmodule
Verilog code for the full-adder using continuous
assignment.

module fulladd (Cin, x, y, s, Cout);
input Cin, x, y;
output s, Cout;
assign s = x ^ y ^ Cin,
Cout = (x & y) | (x & Cin) | (y & Cin);
endmodule
Another version of Verilog code

## **Ripple Carry Adder (RCA)**

- Create a separate Verilog module for the ripplecarry adder, which instantiates the *fulladd* module as a sub circuit.
- One method of doing this is shown.
- The module comprises the code for a four-bit ripple-carry adder, named *adder4*.
- One of the 4-bit numbers to be added is represented by the four signals x3, x2, x1, x0, and the other is represented by y3, y2, y1, y0.
- The sum is represented by s3, s2, s1, s0.
- The circuit incorporates a carry input, *carryin*, into the lsb position and a carry output, *carryout*, from the msb position.

module adder4 (carryin, x3, x2, x1, x0, y3, y2, y1, y0, s3, s2, s1, s0, carryout); input carryin, x3, x2, x1, x0, y3, y2, y1, y0; output s3, s2, s1, s0, carryout; fulladd stage0 (carryin, x0, y0, s0, c1); fulladd stage1 (c1, x1, y1, s1, c2); fulladd stage2 (c2, x2, y2, s2, c3); fulladd stage3 (c3, x3, y3, s3, carryout); endmodule module fulladd (Cin, x, y, s, Cout); input Cin, x, y; output s, Cout; assign  $s = x \wedge y \wedge Cin$ ; assign Cout = (x & y) | (x & Cin) | (y & Cin); endmodule Verilog code for a four-bit adder.



- Each statement begins with the name of the module, *fulladd*, that is being instantiated, followed by an *instance name*.
- The instance names must be unique.
- The least-significant stage in the adder is named *stage0* and the most-significant stage is *stage3*.
- The signal names in the *adder4* module that are to be connected to each input and output port on the *fulladd* module are then listed.
- These signals are listed in the same order as in the *fulladd* module, namely the order *Cin*, *x*, *y*, *s*, *Cout*.



- The signal names associated with each instance of the *fulladd* module implicitly specify how the full-adders are connected together.
- For example, the carry-out of the *stage0* instance is connected to the carry-in of the *stage1* instance.
- The synthesized circuit has the same structure as the original block diagram.
- The *fulladd* module may be included in the same Verilog source code file as the *adder4* module.
- If compiler needs the function, create another file *fulladd* and the location of the file *fulladd* has to be indicated to the compiler.



An example of an input vector is,

input [3:0] X;

This statement defines X to be a four-bit vector.

Its individual bits can be referred to by using an index value in square brackets.

The (MSB) is referred to as X [3] and the (LSB) is X [0].

A two-bit vector that consists of the two middle bits of X is denoted as X [2:1].

The symbol X refers to the entire vector.



- Signal C[1] is used to connect the carry output of the full-adder in stage 0 to the carry input of the full-adder in stage 1.
- Similarly, C[2] and C[3] are used to connect the other stages of the adder.
- The vector specification gives the bit width in square brackets, as in *X* [3:0].
- The bit width is specified using the index of the MSB first and the LSB last.
- Hence, X [3] is the MSB and X [0] is the LSB.

module adder4 (carryin, X, Y, S, carryout);
input carryin;
input [3:0] X, Y;
output [3:0] S;
output carryout;
wire [3:1] C;
fulladd stage0 (carryin, X[0], Y[0], S[0], C[1]);
fulladd stage1 (C[1], X[1], Y[1], S[1], C[2]);
fulladd stage2 (C[2], X[2], Y[2], S[2], C[3]);
fulladd stage3 (C[3], X[3], Y[3], S[3], carryout);
endmodule
A four-bit adder using vectors.

#### The Conditional Operator

- In a logic circuit it is needed to choose between several possible signals or values.
- It's based on the state of some condition.
- An example is a multiplexer circuit in which the output is equal to the data input signal chosen by the valuation of the select inputs.
- For simple implementation of such choices Verilog provides a *conditional* operator (?:) which assigns one of two values depending on a conditional expression.
- It involves three operands used in the syntax
- conditional\_expression ? true\_expression : false\_expression

- If the conditional expression evaluates to 1 (true), then the value of true\_expression is chosen;
- otherwise, the value of false\_expression is chosen.
- For example, the statement
- A= (B < C) ? (D + 5) : (D + 2);
- means that if B is less than C, the value of A will be D + 5, or else A will have value D + 2.
- The conditional operator can be used both in continuous assignment statements and in procedural statements inside an **always** block.



- The module, named *mux2to1*, has the inputs *w*0, *w*1, and *s*, and the output *f*.
- The signal *s* is used for the selection criterion.
- The output *f* is equal to *w*1 if the select input *s* has the value 1;
- otherwise, *f* is equal to *w*0.

module mux2to1 (w0, w1, s, f);
input w0, w1, s;
output f;

**assign** f = s ? w1 : w0;

#### endmodule

A 2-to-1 multiplexer specified using the conditional operator.

module mux2to1 (w0, w1, s, f);
input w0, w1, s;
output reg f;

**always** @(w0, w1, s) f = s ? w1 : w0;

endmodule

An alternative specification of a 2-to-1 multiplexer using the conditional operator.

#### The If-Else Statement

```
if(conditional_expression)
statement;
else statement;
```

- The conditional expression may use the relational operators.
- If the expression is evaluated to true then the first statement (or a block of statements delineated by **begin** and **end** keywords) is executed, or else the second statement (or a block of statements) is executed.



```
module mux2to1 (w0, w1, s, f);
input w0, w1, s;
output reg f;
always @(w0, w1, s)
if (s == 0)
f = w0;
else
f = w1;
endmodule
Code for a 2-to-1 multiplexer using the
if-else statement.
```



```
module mux4to1 (w0, w1, w2, w3, S, f);
input w0, w1, w2, w3;
input [1:0] S;
output reg f;
always @(*)
    if (S == 2'b00)
        f = w0;
    else if (S == 2'b01)
        f = w1;
    else if (S == 2'b10)
        f = w2;
    else
        f = w3;
endmodule
```



```
module mux4to1 (W, S, f);
input [0:3] W;
input [1:0] S;
output reg f;
always @(W, S)
if (S == 0)
    f = W[0];
else if (S == 1)
    f = W[1];
else if (S == 2)
    f = W[2];
else
    f = W[3];
```







- Since mux4to1 module is being instantiated in the code, it is necessary to either include the code in same file as the mux16to1 module or place the mux4to1 module in a separate file in same directory.
- Observe that if the scalar code were used as the required *mux4to1* module, then need to list the ports separately, as in *W*[0], *W*[1], *W*[2], *W*[3], rather than as the vector *W*[0:3].

```
module mux16to1 (W, S, f);
    input [0:15] W;
    input [3:0] S;
    output f;
    wire [0:3] M;
    mux4to1 Mux1 (W[0:3], S[1:0], M[0]);
    mux4to1 Mux2 (W[4:7], S[1:0], M[1]);
    mux4to1 Mux3 (W[8:11], S[1:0], M[2]);
    mux4to1 Mux4 (W[12:15], S[1:0], M[3]);
    mux4to1 Mux5 (M[0:3], S[3:2], f);
endmodule
    Hierarchical code for a 16-to-1 multiplexer.
```




### 4:1 MUX using case statement

- The case statement can be used to define a 4-to-1 multiplexer.
- The four values that the select vector *S* can have are given as decimal numbers, but they could also be given as binary numbers.

### 2-to-4 Binary Decoder

- A **case** statement can be used to describe the truth table for a 2-to-4 binary decoder.
- The data inputs are two-bit vector *W*, and the enable input is *En*.
- The four outputs are represented by the four-bit vector *Y*.
- In truth table, the inputs are listed in the order *En*, *w*1, *w*0.
- To represent these three signals in the controlling expression, Verilog code uses concatenate operator to combine the *En* and *W* signals into a three-bit vector.
- The four alternatives in the **case** statement correspond to the truth table in where *En* = 1, and the decoder outputs have the same patterns as in the first four rows of the truth table.
- The last clause uses the **default** keyword and sets the decoder outputs to 0000, because it represents all other cases, namely those where *En* = 0.





```
module dec2to4 (W, En, Y);
  input [1:0] W;
  input En;
  output reg [0:3] Y;
  always @(W, En)
  begin
     if (En == 0)
        Y = 4'b0000;
     else
        case (W)
           0: Y = 4'b1000;
           1: Y = 4'b0100;
           2: Y = 4'b0010;
           3: Y = 4'b0001;
        endcase
  end
endmodule
                Alternative code for a 2-to-4 binary
                decoder.
```









- The SR latch is a circuit with two cross-coupled NOR gates or two cross-coupled NAND gates, and two i/ps labeled S for set and R for reset.
- The latch has two useful States.
- When output Q = 1 and Q' = 0, the latch is said to be in the *set state*.
- When Q = 0 and Q' = 1, it is in the *reset state*.
- Outputs *Q* and *Q* are normally the <u>complement</u> of each other.
- However, when both inputs are equal to 1 at the same time, a condition in which both outputs are equal to 0 occurs.
- If both inputs are then switched to 0 simultaneously, the device will enter an unpredictable or undefined state or a metastable state.
- So, in practical applications, setting both inputs to 1 is forbidden.

- Under normal conditions, both I /ps of the latch remain at 0 unless the state has to be changed.
- The application of a 1 to the *S* input causes the latch to go to the set state.
- The S input must go back to 0 before any other changes take place, in order to avoid the occurrence of an undefined next state that results from the forbidden input condition.
- As shown in the function table, two i/p conditions cause the circuit to be in set state.

- The first condition (*S* = 1,*R* = 0) is the action that must be taken by input *S* to bring the circuit to the set state.
- Removing the active i/p from S leaves the circuit in same state.
- After both i/ps return to 0, it is then possible to shift to the reset state by applying a 1 to the *R* input.
- The 1 can then be removed from *R*, whereupon the circuit remains in the reset state.
- Thus, when both i/ps S and R are equal to 0, the latch can be in either the set or the reset state, depending on which input was most recently a 1.
- If a 1 is applied to both the S and R inputs of the latch, both outputs go to 0.
- In normal operation, this condition is avoided by making sure that 1's are not applied to both inputs simultaneously.





- To change to the reset state, the inputs must be *S* = 0, *R* = 1, and *En* = 1.
- In either case, when *En* returns to 0, the circuit remains in its current state.
- The control input disables the circuit by applying 0 to *En*, so that the state of the output does not change regardless of the values of *S* and *R*.
- Moreover, when *En* = 1 and both the *S* and *R* inputs are equal to 0, the state of the circuit does not change.

- An indeterminate condition occurs when all three inputs are equal to 1.
- This condition places 0's on both inputs of the basic *SR* latch, which puts it in the undefined state.
- When the enable input goes back to 0, one cannot conclusively determine the next state, because it depends on whether the S or R input goes to 0 first.
- This indeterminate condition makes this circuit difficult to manage, and it is seldom used in practice.
- SR latch is an important circuit because other useful latches and flip-flops are constructed from it.





- If *D* = 1, the *Q* output goes to 1, placing the circuit in the set state.
- If *D* = 0, output *Q* goes to 0, placing the circuit in the reset state.









- <u>Flip-flop</u> circuits are built to make them operate properly when they are part of a sequential circuit that employs a <u>common clock</u>.
- The problem with the <u>latch</u> is that it responds to a change in the <u>level</u> of a clock pulse.
- The key to the proper operation of a flip-flop is to trigger it only during a signal <u>transition</u>.
- A clock pulse goes through two transitions: from
   0 to 1 · Positive Edge response
  - from 1 to 0 · Negative Edge response



# Latch 🗆 Flip-Flop

- Modify a latch to form a flip-flop.
  - Use two latches in a <u>special configuration</u> that isolates o/p of flip-flop, prevents it from being affected while i/p to flip-flop is changing.
  - To produce a flip-flop that triggers only during a signal transition (from 0 to 1 or from 1 to 0) of synchronizing signal (clock) and is <u>disabled</u> during rest of the clock pulse.







## Graphic Symbol for ET or M-S D FF

- It is similar to the symbol used for the *D* latch, except for the arrowhead-like symbol in front of the letter *Clk*, designating a *dynamic* input.
- The *dynamic indicator* (>) indicates that flipflop responds to the <u>edge transition</u> of clock.
- A bubble besides dynamic indicator indicates a negative edge for triggering the circuit.
- Absence of a bubble designates a positiveedge response.













| J       K $Q(t + 1)$ 0       0 $Q(t)$ No change         0       1       0       Reset         1       0       1       Set         1       1 $Q'(t)$ Complement         D Flip-Flop       T Flip-Flop         D $Q(t + 1)$ $T = 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |                   | JK I                 | Flip-Fl | op       |                        |                                |           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------------|----------------------|---------|----------|------------------------|--------------------------------|-----------|
| $\begin{array}{c ccccc} 0 & 0 & Q(t) & \text{No change} \\ 0 & 1 & 0 & \text{Reset} \\ 1 & 0 & 1 & \text{Set} \\ 1 & 1 & Q'(t) & \text{Complement} \\ \hline \textbf{D Flip-Flop} & \textbf{T Flip-Flop} \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & \textbf{T} & Q(t+1) \\ \hline \textbf{D} & Q(t+1) & T$ |          |                   | J                    | K       | Q(t + t) | 1)                     |                                |           |
| $\begin{array}{c cccc} 0 & 1 & 0 & \text{Reset} \\ 1 & 0 & 1 & \text{Set} \\ 1 & 1 & Q'(t) & \text{Complement} \\ \hline D \ Flip-Flop & T \ Flip-Flop \\ \hline D \ O(t + 1) & T & O(t + 1) \\ \hline \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |                   | 0                    | 0       | Q(t)     | Ì                      | No change                      |           |
| $\begin{array}{c cccc} 1 & 0 & 1 & \text{Set} \\ 1 & 1 & Q'(t) & \text{Complement} \\ \hline D \ Flip-Flop & T \ Flip-Flop & T \ O(t + 1) & T & O(t + 1) \\ \hline \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |                   | 0                    | 1       | 0        |                        | Reset                          |           |
| $\begin{array}{c cccc} 1 & 1 & Q'(t) & \text{Complement} \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |          |                   | 1                    | 0       | 1        |                        | Set                            |           |
| D Flip-Flop $T$ Flip-Flop $T = 0(t + 1)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                   | 1                    | 1       | Q'(t)    |                        | Complement                     | t         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |                   | Flip-Flop $O(t + 1)$ |         |          |                        |                                |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | D F<br>D | lip-Flor<br>Q(t + | <b>1</b> )           | Reset   |          | <b>T</b> F<br><b>T</b> | $\frac{\mathbf{P}(t+1)}{O(t)}$ | No change |

| <b>Characteristic Equations</b>                   |
|---------------------------------------------------|
| D flip Flop · $Q(t + 1) = D$                      |
| JK flip Flop $\cdot Q(t+1) = JQ' + K'Q$           |
| T flip Flop · $Q(t + 1) = T \oplus Q = TQ' + T'Q$ |

|      | SR Flip | -flop |   | D Flip-flop |        |    |  |
|------|---------|-------|---|-------------|--------|----|--|
| Q(t) | Q(t+1)  | S     | R | Q(t)        | Q(t+1) | DR |  |
| 0    | 0       | 0     | X | 0           | 0      | 0  |  |
| 0    | 1       | 1     | 0 | 0           | 1      | 1  |  |
| 1    | 0       | 0     | 1 | 1           | 0      | 0  |  |
| 1    | 1       | X     | 0 | 1           | 1      | 1  |  |
|      | JK flip | -flop |   | T flip-flop |        |    |  |
| Q(t) | Q(t+1)  | J     | K | Q(t)        | Q(t+1) | DR |  |
| 0    | 0       | 0     | x | 0           | 0      | 0  |  |
| 0    | 1       | 1     | X | 0           | 1      | 1  |  |
| 0    |         |       | 1 | 1           | 0      | 1  |  |
| 1    | 0       | A     |   | -           |        |    |  |

### **Binary Ripple Counter**

- A binary ripple counter consists of a series connection of T flip-flops, with output of each flip-flop connected to *Clk* input of next higher order flip-flop.
- The flip-flop holding the *l*sb receives incoming count pulses.
- Also can use *D* flip-flop with complement output connected to the *D* input.
- So, the *D* input is always the complement of the present state, and the next clock pulse will cause the flip-flop to complement.





| A <sub>3</sub> | A <sub>2</sub> | A1 | Ao |
|----------------|----------------|----|----|
| 0              | 0              | 0  | 0  |
| 0              | 0              | 0  | 1  |
| 0              | 0              | 1  | 0  |
| 0              | 0              | 1  | 1  |
| 0              | 1              | 0  | 0  |
| 0              | 1              | 0  | 1  |
| 0              | 1              | 1  | 0  |
| 0              | 1              | 1  | 1  |
| 1              | 0              | 0  | 0  |

## **Operation of Ripple Counter**

- The lsb, A0, is complemented with each count pulse input.
- Every time that A0 goes from 1 to 0, it complements A1.
- Every time that A1 goes from 1 to 0, it complements A2.
- Every time that A2 goes from 1 to 0, it complements A3, and so on for any other higher order bits of a ripple counter.
- <u>For example</u>, consider transition from count 0011 to 0100.
- A0 is complemented with the count pulse.
- Since A0 goes from 1 to 0, it triggers A1, complements it.
- As a result, A1 goes from 1 to 0, which in turn complements A2, changing it from 0 to 1.
- A2 does not trigger A3, as A2 produces a positive transition and the flip-flop responds only to negative transitions.

- Thus, the count from 0011 to 0100 is achieved by changing the bits one at a time, so the count goes from 0011 to 0010, then to 0000, and finally to 0100.
- The flip-flops change one at a time in succession, and the signal propagates through the counter in a <u>ripple fashion</u> from one stage to the next.

#### Synchronous counters

- Synchronous counters are different from ripple counters in that clock pulses are applied to the inputs of all flip-flops.
- A common clock triggers all flip-flops simultaneously, rather than one at a time in succession as in a ripple counter.
- The decision whether a flip-flop is to be inverted is determined from the values of the data inputs, such as *T* or *J* and *K* at the time of the clock edge.
- If T = 0 or J = K = 0, flip-flop does not change state.
- If T = 1 or J = K = 1, the flip-flop complements.



- In a synchronous binary counter, the flip-flop in the least significant position is complemented with every pulse.
- A flip-flop in any other position is complemented when all the bits in the lower significant positions are equal to 1.
- For example, if the present state of a four-bit counter is A3A2A1A0 = 0011, the next count is 0100.
- A0 is always complemented.
- A1 is complemented as the present state of A0 = 1.
- A2 is complemented as present state of A1A0 = 11.
- But, A3 is not complemented, as present state of A2A1A0 = 011, which is not an all-1's condition.

- Synchronous binary counters have a regular pattern and can be built with J K Flip Flops and Gates.
- *C* inputs of all flip-flops are connected to a common clock.
- The counter is enabled by *Count\_enable*.
- If the enable input is 0, all J and K inputs are equal to 0 and the clock does not change the state of the counter.
- First stage, A0, has its J=1 and K =1 if counter is enabled.
- The other J and K inputs are equal to 1 if all previous least significant stages are equal to 1 and the count is enabled.
- The chain of AND gates generates the required logic for the *J* and *K* inputs in each stage.

- In general, Counter can have any no: of stages, with each stage having an addnl flip-flop and an AND gate that gives an output of 1 if all previous flip-flop outputs are 1.
- Note that the flip-flops trigger on the positive edge of the clock.
- The polarity of the clock is not essential here, but it is with the ripple counter.
- The synchronous counter can be triggered with either the positive or the negative clock edge.







- A four-bit shift register is used to shift its contents one bit position to the right.
- The data bits are loaded into the shift register in a serial fashion using the *In* input.
- The contents of each flip-flop are transferred to the next flip-flop at each positive edge of the clock.
- Figure *b*, shows what happens when the signal values at *In* during eight consecutive clock cycles are 1, 0, 1, 1, 1, 0, 0, and 0, assuming that the initial state of all flip-flops is 0.



- A four-bit shift register provides the parallel access.
- A 2-to-1 MUX on its *D* input allows each flip-flop to be connected to two different sources.
- One source is the preceding flip-flop, which is needed for the shift-register operation.
- The other source is the external i/p that corresponds to the bit that is to be loaded into the flip-flop as a part of the parallel-load operation.
- The control signal *Shift/Load* is used to select the mode of operation.
- If *Shift/Load* = 0, then circuit operates as a shift register.
- If *Shift/Load* = 1, then the parallel input data are loaded into the register.
- In both cases the action takes place on the positive edge of the clock



- Label the flip-flops' outputs as Q3, ..., Q0 as shift registers are often used to hold binary numbers.
- The contents of the register can be accessed in <u>parallel</u> by observing the outputs of all flip-flops.
- The flip-flops can also be accessed <u>serially</u>, by observing the values of Q0 during consecutive clock cycles while the contents are being shifted.
- A circuit in which data can be loaded in <u>series</u> and then accessed in <u>parallel</u> is called a **series-to**parallel converter.
- Similarly, the opposite type of circuit is a **parallel**to-series converter.







- Since the clear inputs are active when low, a NAND gate is used to detect the occurrence of the count of 5 and cause the clearing of all three flip-flops.
- As soon as the count reaches this value, the NAND gate triggers the resetting action.
- The flip-flops are cleared to 0 a short time after NAND gate has detected the count of 5.

### **Ring Counter**

- Design a Counter in which each flip-flop reaches the state Q<sub>i</sub> = 1 for exactly one count, for all other counts Q<sub>i</sub> = 0.
- Q<sub>i</sub> indicates directly occurrence of corresponding count.
- Such a circuit can be built from a simple shift register.
- The Q output of the last stage in the shift register is fed back as the input to the first stage, which creates a ring -like structure.
- If a single 1 is injected into the ring, this 1 will be shifted through the ring at successive clock cycles.
- For example, in a four-bit structure, the possible codes  $Q_0Q_1Q_2Q_3$  will be 1000, 0100, 0010, and 0001.
- Such encoding, where there is a single 1 and the rest of the code variables are 0, is called a *One-Hot Code*.
- Such a circuit is referred to as a <u>Ring Counter</u>.
















- where A is a variable of **reg** type.
- This code specifies that the value of A should be made equal to value of B when Control = 1.
- But the statement does not indicate an action that should occur when *Control* = 0.
- In the absence of an assigned value, the Verilog compiler assumes that the value of *A* caused by the **if** statement must be maintained when *Control* is not equal to 1.
- This notion of *implied memory* is realized by <u>instantiating</u> a latch in the circuit.

```
module D_latch (D, Clk, Q);

input D, Clk;

output reg Q;

always @(D, Clk)

if (Clk)

Q = D;

endmodule

Code for a gated D latch.
```

- The code defines a module named *D\_latch*, which has inputs *D* and *Clk* and the output Q.
- The **if** clause defines that the Q output must take the value of *D* when *Clk* = 1.
- Since no **else** clause is given, a latch will be synthesized to maintain value of Q when *Clk*=0.
- Therefore, the code describes a gated D latch.
- The <u>sensitivity list</u> includes *Clk* and *D* because both of these signals can cause a <u>change</u> in the value of the Q output.

- An **always** construct is used to define a circuit that responds to changes in the signals that appear in the sensitivity list.
- The always blocks are sensitive to the *levels* of signals, it is also possible to specify that a response should take place only at a particular edge of a signal.
- The desired edge is specified by using the Verilog keywords **posedge** and **negedge**, which are used to implement edge-triggered circuits.









- Using non-blocking assignments.
- In the two statements
- Q1 <= D;
- Q2 <= Q1;
- The variables Q1 and Q2 have some value at the start of evaluating the **always** block, and
- Then they change to a new value concurrently at the end of the **always** block.
- This code generates a <u>cascaded connection</u> between flip-flops, which implements the shift register.

```
module example5_5 (x1, x2, x3, Clock, f, g);
input x1, x2, x3, Clock;
output reg f, g;
always @(posedge Clock)
begin
    f = x1 & x2;
    g = f | x3;
end
endmodule
```





- This is a module that defines a D flip-flop with an asynchronous active-low reset (clear) input.
- When *Resetn*, the reset input, is equal to 0, the flip-flop's Q output is set to 0.
- Note that the sensitivity list specifies the negative edge of *Resetn* as an event trigger along with the positive edge of the clock.
- It's not possible to omit the keyword **negedge** because the sensitivity list cannot have both edge-triggered and level sensitive signals.





- In this case the reset signal is acted upon only when a positive clock edge arrives.
- This code generates the circuit which has an AND gate connected to the flip-flop's D input.

## **AN N-BIT REGISTER**

- Since registers of different sizes are often needed in logic circuits, it is useful to define a register module for which the number of flipflops can be easily changed.
- The code for an *n*-bit register is given.
- The parameter *n* specifies the number of flipflops in the register.
- By changing this parameter, the code can represent a register of any size.





```
module muxdff (D0, D1, Sel, Clock, Q);
input D0, D1, Sel, Clock;
output reg Q;
always @(posedge Clock)
if (!Sel)
    Q <= D0;
else
    Q <= D1;
endmodule
Code for a D flip-flop with a 2-to-1 multiplexer on
the D input.</pre>
```



- The module *Stage3* instantiates the leftmost flip-flop, which has the output Q3, and the module *Stage0* instantiates the right-most flip-flop, Q0.
- When L = 1, the register is loaded in parallel from the R input; and when L = 0, shifting takes place in the left to right direction.
- · Serial data is shifted into the most significant
- bit, Q3, from the *w* input.

```
module muxdff (D0, D1, Sel, Clock, Q);
input D0, D1, Sel, Clock;
output reg Q;
wire D;
assign D = Sel ? D1 : D0;
always @(posedge Clock)
Q <= D;
endmodule
Alternative code for a D flip-flop with a 2-to-1
multiplexer on the D input.</pre>
```

| <pre>module shift4 (R, L, w, Clock, Q); input [3:0] R; input L, w, Clock; output wire [3:0] Q;</pre>                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| muxdff Stage3 (w, R[3], L, Clock, Q[3]);<br>muxdff Stage2 (Q[3], R[2], L, Clock, Q[2]);<br>muxdff Stage1 (Q[2], R[1], L, Clock, Q[1]);<br>muxdff Stage0 (Q[1], R[0], L, Clock, Q[0]); |
| endr                                                                                                                                                                                  |
| Hierarchical code for a four-bit shift register.                                                                                                                                      |
|                                                                                                                                                                                       |

```
module shift4 (R, L, w, Clock, Q);
  input [3:0] R;
  input L, w, Clock;
  output reg [3:0] Q;
  always @(posedge Clock)
     if (L)
        Q \leq R;
     else
     begin
        Q[0] < = Q[1];
        Q[1] <= Q[2];
        Q[2] <= Q[3];
        Q[3] <= w;
     end
endmodule
                Alternative code for a four-bit shift register.
```

```
module shiftn (R, L, w, Clock, Q);
   parameter n = 16;
   input [n-1:0] R;
   input L, w, Clock;
   output reg [n-1:0] Q;
   integer k;
   always @(posedge Clock)
      if (L)
         Q \leq = R;
      else
      begin
         for (k = 0; k < n - 1; k = k+1)
            Q[k] < = Q[k+1];
         Q[n-1] < = w;
      end
endmodule
L
                 An n-bit shift register.
```

## **AN N-BIT SHIFT REGISTER**

- This is the code that can be used to represent shift registers of any size.
- The parameter *n*, which has the default value 16, sets the number of flip-flops.
- First, *R* and Q are defined in terms of *n*.
- Second, the **else** clause that describes the shifting operation is generalized to work for any number of flip-flops by using a **for** loop.







# Logic Families and its Characteristics

ECT 203 Module V

#### **BASIC OPERATIONAL CHARACTERISTICS AND PARAMETERS** Operational properties include voltage levels, noise immunity, • power dissipation, fan-out, and propagation delay time. **DC Supply Voltage** The nominal value of the dc supply voltage for TTL(Transistor-Transistor Logic) devices is +5 V. TTL is also designated $T^2L$ . CMOS (Complementary Metal-Oxide Semiconductor) devices are available in different supply voltage categories: +5 V, 3.3 V, 2.5 V and 1.2 V. Although omitted from logic diagrams for simplicity, the dc supply ٠ voltage is connected to the Vn pin of an IC package, and ground is connected to the GND pin. Both voltage and ground are distributed internally to all elements ٠ within the package, as illustrated as shown below for a 14-pin package.













## **Noise Immunity**

- Noise is unwanted voltage that is induced in electrical circuits and can present a threat to the proper operation of the circuit.
- Wires and other conductors within a system can pick up stray high-frequency electromagnetic radiation from adjacent conductors in which currents are changing rapidly or from many other sources external to the system.
- Also, power-line voltage fluctuation is a form of low-frequency noise.

- In order not to be adversely affected by noise, a logic circuit must have a certain amount of noise immunity.
  This is the ability to tolerate a certain amount of
- This is the ability to tolerate a certain amount of unwanted voltage fluctuation on its inputs without changing its output state.
- For example, if noise voltage causes the input of a 5 V CMOS gate to drop below 3.5V in the HIGH state, the input is in the unallowed region and operation is unpredictable.
- Thus, the gate may interpret the fluctuation below 3.5 V as a LOW level.
- Similarly, if noise causes a gate input to go above 1.5 V in the LOW state, an uncertain condition is created.







- The noise margin is expressed as a percentage of Vcc.
- From equations.  $V_{NH}$  is the difference between the lowest possible HIGH output from a driving gate ( $V_{OH(min)}$ ) and the lowest possible HIGH input that the load gate can tolerate ( $V_{IH(min)}$ ).
- Noise margin,  $V_{NL}$  is the difference between the maximum possible LOW input that a gate can tolerate ( $V_{IL(max)}$ ) and the maximum possible LOW output of the driving gate ( $V_{OL(max)}$ ).





For TTL,

$$\begin{split} V_{\rm IH(min)} &= 2 \ V \\ V_{\rm IL(max)} &= 0.8 \ V \\ V_{\rm OH(min)} &= 2.4 \ V \\ V_{\rm OH(min)} &= 0.4 \ V \\ V_{\rm NH} &= V_{\rm OH(min)} - V_{\rm IH(min)} = 2.4 \ V - 2 \ V = 0.4 \ V \\ V_{\rm NH} &= V_{\rm IL(max)} - V_{\rm OL(max)} = 0.8 \ V - 0.4 \ V = 0.4 \ V \end{split}$$

A TTL gate is immune to up to 0.4 V of noise for both the HIGH and LOW input states.

Based on the preceding noise margin calculations, which family of devices, 5 V CMOS or TTL, should be used in a high-noise environment?







## EXAMPLE -2

A certain gate draws 2  $\mu$ A when its output is HIGH and 3.6  $\mu$ A when its output is LOW. What is its average power dissipation if V<sub>cc</sub> is 5 V and the gate is operated on a 50% duty cycle? **Sol** 

The average Icc is

$$I_{\rm CC} = \frac{I_{\rm CCH} + I_{\rm CCL}}{2} = \frac{2.0\,\mu\text{A} + 3.6\,\mu\text{A}}{2} = 2.8\,\mu\text{A}$$

The average power dissipation is

$$P_{\rm D} = V_{\rm CC} I_{\rm CC} = (5 \, \text{V})(2.8 \, \mu\text{A}) = 14 \, \mu\text{W}$$

### Homework!

**1**. A certain IC gate has an  $I_{CCH}$  = 1.5µA and  $I_{CCL}$  = 2.8 µA. Determine the average Power dissipation for 50% duty cycle operation if V<sub>cc</sub> is 5 V.

### 2.

Based on the preceding noise margin calculations, which family of devices, 5 V CMOS or TTL, should be used in a high-noise environment?

## Power dissipation TTL vs CMOS

- Power dissipation in a TTL circuit is essentially constant over its range of operating frequencies.
- Power dissipation in CMOS, however, is frequency dependent.
- It is extremely low under static (dc) conditions and increases as the frequency increases.











# **Speed-Power Product**

- The speed-power product provides a basis for the comparison of logic circuits when both propagation delay time and power dissipation are important considerations in the selection of the type of logic to be used in a certain application.
- The lower the speed-power product, the better. The unit of speed-power product is the pico-joule (pJ).
- For ex, HCMOS has a speed-power product of 1.2 pJ at I00 kHz while LS TTL has a value of 22 pJ.



# **CMOS Loading**

- Loading in CMOS differs from that in TTL because the type of transistors used in CMOS logic present a <u>predominantly capacitive load</u> to driving gate.
- In this case, the limitations are the charging and discharging times associated with the output resistance of the driving gate and the input capacitance of the load gates.
- When the output of the driving gate is HIGH, the input capacitance of the load gate is charging through the output resistance of the driving gate.
- When the output of the driving gate is LOW, the capacitance is discharging.



- When more load gate inputs are added to the driving gate output, the total capacitance increases because the input capacitances effectively appear in parallel.
- This increase in capacitance increases the charging and discharging limes, thus reducing the maximum frequency at which the gate can be operated.
- Therefore, the fan-out of a CMOS gate depends on the frequency of operation.
- The fewer the load gate inputs, the greater the maximum frequency.

# **TTL Loading**

- A TTL driving gate sources current to a load gate input in the HIGH state( $I_{IH}$ ) and sinks current from the load gate in LOW state ( $I_{IL}$ ).
- Current sourcing and current sinking are illustrated in simplified form.
- Where the resistors represent the internal input and output resistance of the gate for the two conditions.









| <ul> <li>The fan-out is the max no: of load gate inputs that can<br/>be connected without adversely affecting the specified<br/>operational characteristics of the gate.</li> </ul>                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>For ex, low power Schottky (LS) TTL has a fan-out of 20<br/>unit loads.</li> </ul>                                                                                                                           |
| <ul> <li>One input of the same logic family as the driving gate is<br/>called a unit load.</li> </ul>                                                                                                                 |
| <ul> <li>The total sink current also increases with each load<br/>gate input that is added, as shown.</li> </ul>                                                                                                      |
| <ul> <li>As this current increases, the internal voltage drop of<br/>the driving gale increases. causing V<sub>OL</sub> increase.</li> </ul>                                                                          |
| <ul> <li>If an excessive number of loads are added V<sub>OL</sub> exceeds V<sub>OL(max)</sub> and the LOW-level noise margin is reduced.</li> <li>In TTL the current-sinking capability (LOW output state)</li> </ul> |
| is the limiting factor in determining the fan-out.                                                                                                                                                                    |




### **TTL Inverter**

- The logic function of an inverter or any type of gate is always the same, regardless of the type of circuit technology that is used.
- A standard TTL circuit for an inverter is studied.
- In this diagram Q<sub>1</sub> is the <u>input coupling transistor</u>, and D, is the input clamp diode.
- Transistor  $Q_2$  is called a <u>phase splitter</u>, and the combination of  $Q_3$  and  $Q_4$  forms the output circuit often referred to as a <u>totem-pole</u> <u>arrangement</u>.



#### Operation

- When the input is a HIGH, the base-emitter junction of Q<sub>1</sub> is reverse biased, and the base-collector junction is forward biased.
- This condition permits current through  $R_1$  and the base-collector junction of  $Q_1$ , into the base of  $Q_2$ , thus driving  $Q_2$  into saturation.
- As a result  $Q_3$  is turned on by  $Q_2$  and its collector voltage, which is the output, is near ground potential.
- We therefore have a LOW output for a HIGH input.
- At the same time, the col lector of  $Q_2$  is at a sufficiently low voltage level to keep  $Q_4$  off.
- When the input is LOW the base-emitter junction of Q<sub>1</sub> is forward biased, and the base collector junction is reverse biased.
- There is current through  $\mathsf{R}_1$  and the base-emitter junction of Q1 to the LOW input.





• Diode  $D_2$  provides an additional  $V_{BE}$  equivalent drop in series with the base-emitter junction of  $Q_4$  to ensure its turn-off when  $Q_2$  is on.











# **CMOS CIRCUITS** - The MOSFET

- Metal-oxide semiconductor field-effect transistors (MOSFETs) are the active switching elements in CMOS circuits.
- These devices differ greatly in construction and internal operation from bipolar junction transistors used in TTL circuits, but the switching action is basically the same.
- They function ideally as open or closed switches, depending on the input.

# The MOSFET

- The three terminals of a MOSFET are gate, drain, and source.
- When the gate voltage of an n-channel MOSFET is more positive than the source, the MOSFET is ON (Saturation), and there is ideally, a closed switch between the drain and the source.
- When the gate-to-source voltage is zero, the MOSFET is OFF (cutoff), and there is ideally, an open switch between the drain and the source.









| <ul> <li>Complementary MOS (CMOS) logic uses the<br/>MOSFET in complementary pairs as its basic<br/>element.</li> </ul>                                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>A complementary pair uses both n -channel and<br/>p-channel enhancement MOSFETs.</li> </ul>                                                   |
| <ul> <li>When a HIGH is applied to the input, the p-<br/>channel MOSFET Q1 is off and the n-channel<br/>MOSFET Q2 is on.</li> </ul>                    |
| <ul> <li>This condition connects the output to ground<br/>through the on resistance of Q2, resulting in a<br/>LOW output.</li> </ul>                   |
| <ul> <li>When a LOW is applied to the input, Q1 is on and<br/>Q2 is off.</li> </ul>                                                                    |
| <ul> <li>This condition connects the output to +VDD (dc<br/>supply voltage) through the on resistance of Q1<br/>resulting in a HIGH output.</li> </ul> |





## CMOS NAND

• The operation of a CMOS NAND gate is as follows:

When both inputs are LOW Q1 and Q2 are on and Q3 and Q4 are off.

The output is pulled HIGH through the on resistance of Q1 and Q2 in parallel.

When input A is LOW and input B is HIGH Q1 and Q4 are on and Q2 and Q3, are off. The output is pulled HIGH through the low on resistance of Q1.

When input A is HIGH and input B is LOW Q1and Q4 are off and Q2 and Q3 are on.

The output is pulled HIGH through the low on resistance of Q2.

Finally, when both inputs are HIGH Q1 and Q2 are off and Q3 and Q4 are on.

In this case, the output is pulled LOW through the on resistance of Q3 and Q4 in series to ground.





When input A is HIGH and input B is LOW Q1 and Q4 are off and Q2 and Q3 are on.

The output is pulled LOW through the on resistance of Q3 to ground.

When both inputs are HIGH Q1 and Q4 are off, and Q2 and Q3 are on.

The output is pulled LOW through the on resistance of Q3 and Q4 in parallel lo ground.

## EMITTER-COUPLED LOGIC (ECL) CIRCUITS

- Emitter-coupled logic, like TTI is a bipolar technology.
- The typical ECL circuit consists of a differential amplifier input circuit, a bias circuit, and emitter-follower outputs.
- ECL is much faster than TTL because the transistors do not operate in saturation and is used in more specialized high-speed applications.







# Operation

- Due to the low output impedance of the emitterfollower and the high input impedance of the differential amplifier input, high fan-out operation is possible.
- In this type of circuit. saturation is not possible. The lack of saturation results in higher power consumption and limited voltage swing (less than IV).
- But it permits high-frequency switching.
- The Vcc pin is normally connected to ground, and the  $V_{EE}$  pin is connected to -5.2 V from the power supply for best operation.
- Notice that the output varies from a LOW level of 1.75 V to a HIGH level of -0.9 V with respect to ground.
- In positive logic a 1 is the HIGH level (less negative), and a 0 is the LOW level (more negative).



|                                 | BIPOLAR (TTL)<br>F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CMOS<br>AHC | BIPOLAR (ECL) |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------|
| Speed                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |               |
| Gate propagation                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |               |
| delay, $I_p$ (ns)               | 3.3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3.7         | 0.22-1        |
| FF maximum<br>clock freq. (MHz) | 145                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 170         | 330-2800      |
| Power Dissipation               | and the second se |             |               |
| Per Gate                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |               |
| Bipolar: 50% de                 | 8.9 mW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             | 25 mW-73 mW   |
| CMOS: quiescent                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2.5 µW      |               |